Vue.js路由深度解析:解决生产环境子路由无法访问的问题

临近下班,发布上线。项目迭代后更新到线上,反馈某些页面点击打不开。 发现都是嵌套的子路由无法访问

但是本地开发环境没问题。猜测本地开发环境做了特殊处理。

栓Q,加班的节奏。🤐

控制台报错:TypeError: i.then is not a function

开启sourceMap后更新到测试服

(只要是build的文件部署后都会报这个错,本地没办法复现,超级麻烦):

TypeError: componentPromise.then is not a function

点击子路由页面控制台报错:
开启sourcemap 再打包 进入报错源码 在vue-router内部。

vue-router在开发环境会自动包一层Promise做兼容处理。 生产环境就不做兼容。所以报错了

调试rawComponent的值

可以发现访问这个子页面的时候它的父组件Layout没加载出来。返回了一个不是promise的箭头函数。执行后rawComponent()返回一个组件。

查看本地的routerMap配置

看源码可以得知 component期望获得一个组件对象,或者一个promise

import的知识:只有动态导入才会返回一个promise。

Layout在这里是静态导入的。再使用箭头函数包裹,返回的只会是一个箭头函数。而不是一个promise。

解决:
疑问
1,查看代码几个月前别人写的。这块一直没人动过。期间一直可以正常访问,突然不行了咋?

未知悬案

2,测试环境 .env.test文件里面是NODE_ENV='test'

按理说 process.env.NODE_ENV 应该也是test才对?
运行的命令:vite build --mode test

看看Vite官网:
process.env.NODE_ENV 是一个在 Node.js 环境中经常使用的环境变量,主要用于区分开发环境和生产环境。 在开发环境中,process.env.NODE_ENV 的值通常被设置为 'development' 在生产环境中,process.env.NODE_ENV 的值通常被设置为 'production'

Vite 官网: cn.vitejs.dev/guide/env-a...

只有build的时候NODE_ENV才会是production。难怪不管什么环境。 只要build后访问就报错。

相关推荐
Nan_Shu_61416 分钟前
学习: Threejs (2)
前端·javascript·学习
G_G#24 分钟前
纯前端js插件实现同一浏览器控制只允许打开一个标签,处理session变更问题
前端·javascript·浏览器标签页通信·只允许一个标签页
@大迁世界40 分钟前
TypeScript 的本质并非类型,而是信任
开发语言·前端·javascript·typescript·ecmascript
GIS之路1 小时前
GDAL 实现矢量裁剪
前端·python·信息可视化
是一个Bug1 小时前
后端开发者视角的前端开发面试题清单(50道)
前端
Amumu121381 小时前
React面向组件编程
开发语言·前端·javascript
持续升级打怪中1 小时前
Vue3 中虚拟滚动与分页加载的实现原理与实践
前端·性能优化
GIS之路1 小时前
GDAL 实现矢量合并
前端
hxjhnct1 小时前
React useContext的缺陷
前端·react.js·前端框架
前端 贾公子2 小时前
从入门到实践:前端 Monorepo 工程化实战(4)
前端