解决 “crypto.hash is not a function”:Vite 从 6.x 升级至 7.x 后 `pnpm run dev` 报错问题

🚀 作者主页: 有来技术

🔥 开源项目: youlai-mallvue3-element-adminyoulai-bootvue-uniapp-template

🌺 仓库主页: GitCodeGiteeGithub

💖 欢迎点赞 👍 收藏 ⭐评论 📝 如有错误敬请纠正!

目录

    • 问题描述
    • 原因分析
      • [核心问题:Node.js 版本不兼容](#核心问题:Node.js 版本不兼容)
    • 解决方案
      • [✅ 方案一:升级 Node.js 至合规版本(推荐)](#✅ 方案一:升级 Node.js 至合规版本(推荐))
      • [⚠️ 方案二:降级 Vite 至 6.x(临时方案)](#⚠️ 方案二:降级 Vite 至 6.x(临时方案))
    • 技术决策建议

问题描述

将 Vite 从 6.x 升级至 7.x 后,执行 pnpm run dev 时出现以下错误:

bash 复制代码
error when starting dev server:  
TypeError: crypto.hash is not a function

原因分析

核心问题:Node.js 版本不兼容

  • Vite 7 的依赖变更 :Vite 7 内部使用 crypto.hash() 等现代 Web Crypto API,该特性仅在 Node.js 20.19.0+ 或 22.12.0+ 中稳定支持。
  • Node.js 21 的定位问题
    • 21.x 属于非 LTS 版本(奇数版本为实验性分支),API 稳定性低于 LTS 版本。
    • 在 Node.js 21 中 crypto.hash() 未完全实现或存在兼容性差异。

解决方案

✅ 方案一:升级 Node.js 至合规版本(推荐)

  1. 安装符合要求的 Node.js 版本

    bash 复制代码
    # 使用 nvm 切换版本(推荐)
    nvm install 22.12.0
    nvm use 22.12.0
  2. 验证 Node.js 版本

    bash 复制代码
    node -v  # 应输出 v22.12.0 或更高
  3. 重新安装依赖并启动

    bash 复制代码
    pnpm install && pnpm run dev

⚠️ 方案二:降级 Vite 至 6.x(临时方案)

修改 package.json 锁定 Vite 版本至 6.x 最新补丁版本,清除缓存并重新安装依赖。

技术决策建议

从技术演进角度,升级 Node.js + 保留 Vite 7 是最优路径。Node.js 22 作为 LTS 版本(2023 年 10 月发布)已修复大量安全漏洞,并原生支持 ES2025 特性集。若项目需长期维护,应优先保障基础设施的现代性。

相关推荐
徐同保1 天前
react useState ts定义类型
前端·react.js·前端框架
linweidong1 天前
让低端机也能飞:Canvas/WebGL/Viz 分层、降级渲染与数据抽样策略
前端框架·webgl·canvas·前端动画·前端面经·css渲染·动画优化
醉方休1 天前
React 官方推荐使用 Vite
前端·react.js·前端框架
浪裡遊2 天前
MUI组件库与主题系统全面指南
开发语言·前端·javascript·vue.js·react.js·前端框架·node.js
浪裡遊2 天前
React开发模式解析:JSX语法与生命周期管理
前端·javascript·react.js·前端框架·ecmascript
爱因斯坦乐2 天前
【vue】I18N国际化管理系统
前端·javascript·vue.js·笔记·前端框架
文心快码BaiduComate2 天前
基于YOLOv8的动漫人脸角色识别系统:Comate完成前端开发
前端·后端·前端框架
ら陈佚晨2 天前
React 18 的核心设计理念:并发渲染
前端·javascript·react.js·前端框架·fiber
EF@蛐蛐堂2 天前
Federation vs Garfish vs Micro-app 微前端选型(二)
前端·vue.js·前端框架
歪歪1002 天前
在哪些场景下适合使用 v-model 机制?
服务器·前端·javascript·servlet·前端框架·js