news 2026/6/16 7:09:35

ERROR in ./node_modules/vue-router/dist/vue-router.mjs 被报错折磨半天?真相竟是……

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ERROR in ./node_modules/vue-router/dist/vue-router.mjs 被报错折磨半天?真相竟是……

文章目录

    • bug描述
    • 心酸过程:我的第一反应:Node 版本不对?
    • 转机:换个关键词搜索
    • 解决方案:锁定版本号!
      • 步骤 1:删除 `^`,固定版本
      • 步骤 2:彻底清理重装
      • 步骤 3:重新启动
    • 血泪教训 & 经验总结
      • 不要盲目换 Node 版本!
      • 老项目务必锁定依赖版本!
      • 遇到报错,先搜完整错误关键词!
      • .mjs 报错 = 现代 JS 语法 + 旧构建工具不兼容
      • 维护老项目时,最好保留一份 package-lock.json!
    • 写在最后

bug描述

今天接到一个“简单”任务:给一个以前的老Vue项目改个小功能。

我信心满满地拉下代码,执行:

npminstallnpmrun serve

结果——直接报错!😓

错误信息赫然写着:

./node_modules/vue-router/dist/vue-router.mjs

心酸过程:我的第一反应:Node 版本不对?

我问同事,他们也说:“我们都能跑,应该是你 Node 版本问题。”

于是……我开始了疯狂的版本切换之旅:
从 v16.17.1 → v18.20.8 → v20.19.4
安了删,删了安,重启终端、清缓存、重装依赖……
整整折腾了 3 个小时!

但——还是报同样的错!

我快崩溃了 😭

转机:换个关键词搜索

实在不行,我冷静下来,复制报错中的关键路径:
@ ./node_modules/vue-router/dist/vue-router.mjs

粘贴到百度,终于!找到了几篇真实踩过坑的人写的记录。

其中一条点醒了我:

安装vue-router时没有指定版本,然后npm自动下的是最新版(vue-router版本太高和vue2起冲突了)

🔥 真相大白:版本自动升级惹的祸!

打开 package.json,一看:

"dependencies":{"vue-router":"^4.0.14",}

问题就出在这个^上!
^4.0.14表示:安装4.x的最新版。

解决方案:锁定版本号!

步骤 1:删除^,固定版本

"dependencies":{"vue-router":"4.0.14",}

步骤 2:彻底清理重装

删除node_modulespackage-lock.json

步骤 3:重新启动

npmrun serve

成功运行!世界清净了!

血泪教训 & 经验总结

不要盲目换 Node 版本!

很多报错和 Node 无关,而是依赖版本冲突。

老项目务必锁定依赖版本!

删除 ^ 和 ~,使用精确版本号,避免自动升级引入不兼容包。

遇到报错,先搜完整错误关键词!

AI 回答可能泛泛而谈,但真实开发者踩过的坑记录往往一针见血。

.mjs 报错 = 现代 JS 语法 + 旧构建工具不兼容

尤其在 Vue 2 项目中,看到 vue-router.mjs 基本就是版本装错了。

维护老项目时,最好保留一份 package-lock.json!

它能确保每次安装的依赖完全一致。

写在最后

这次经历让我深刻体会到:技术问题不怕难,怕的是方向错了还死磕。

下次再遇到奇怪报错,我会先问自己:
“是不是依赖版本不对?是不是新旧框架混用了?”

希望这篇记录能帮到同样被 .mjs 折磨的你!
少走弯路,多喝热水,代码无 bug! 💻✨

✍️ 作者: 一个被老项目虐哭又复活的前端
📅 日期: 2025年12月 17日
🔗 欢迎转发,禁止搬运

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 4:44:30

Spring Boot 深度解析:核心原理与自动配置全解

目录 一、自动配置的核心定义与价值 1. 什么是自动配置? 2. 自动配置解决的核心问题 二、自动配置的底层实现原理 1. 自动配置的入口:SpringBootApplication 2. EnableAutoConfiguration:加载自动配置类 关键步骤:AutoConf…

作者头像 李华
网站建设 2026/6/16 12:33:51

EmotiVoice是否支持批量任务队列?自动化生成秘诀

EmotiVoice是否支持批量任务队列?自动化生成秘诀 在内容工业化生产的今天,AI语音技术早已不再是“能说话”就足够的工具。从有声书平台到游戏开发、从虚拟主播到在线教育,越来越多场景需要大量、个性化、富有情感的语音内容。而人工逐条录制成…

作者头像 李华
网站建设 2026/6/15 13:19:21

1小时打造Excel格式异常检测原型系统

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 构建一个极简的Excel格式异常检测原型,核心功能包括:1) 文件上传区域 2) 自动格式检测(识别日期、数字、文本等列)3) 异常高亮显示 4…

作者头像 李华
网站建设 2026/6/15 13:15:35

破局“卖车难”:汽车销售门店工具解锁增长新密码

一、汽车销售门店的四大瓶颈1. 客户管理混乱,资源流失严重传统模式下,客户资料分散于销售的手机备忘录、微信聊天记录或纸质笔记本,成为“个人资产”而非“门店资产”。行业数据显示,平均客户流失率高达37%,其中60%以上…

作者头像 李华
网站建设 2026/6/15 13:03:49

告别手动调试:Excel格式转换效率提升300%的秘诀

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个Excel格式转换效率对比工具,左侧显示传统处理方式(手动指定exceltype、逐列检查格式),右侧显示自动化处理流程。工具应能上传…

作者头像 李华
网站建设 2026/6/16 8:17:20

NATS在微服务架构中的5个典型应用场景

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 构建一个微服务电商系统演示,包含订单服务、库存服务和支付服务,使用NATS实现服务间通信。要求实现事件驱动的订单处理流程,包含重试机制和死信队…

作者头像 李华