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后访问就报错。

相关推荐
Jiaberrr23 分钟前
页面转 PDF 功能的实现思路与使用方法
前端·javascript·vue.js·微信小程序·pdf·uniapp
XDU小迷弟42 分钟前
第2天:Web应用&架构类别&源码类别&镜像容器&建站模版&编译封装&前后端分离
服务器·前端·安全·web安全·架构·安全架构
热情仔1 小时前
win10 npm login 登陆失败
前端·npm·node.js
_.Switch1 小时前
FastAPI 响应模型与自定义响应
开发语言·前端·数据库·python·fastapi·命令模式
三天不学习1 小时前
Vue Router v3.x 路由进阶【路由篇】
前端·vue.js·路由·router·vue router
dowhileprogramming1 小时前
Python 中常见的数据结构之一嵌套字典
前端·数据结构·python
ryipei1 小时前
把vue项目或者vue组件发布成npm包或者打包成lib库文件本地使用
前端·vue.js·npm
赵大仁2 小时前
Uniapp中使用`wxml-to-canvas`开发DOM生成图片功能
前端·javascript·微信小程序·uni-app
雯0609~2 小时前
uni-app:实现普通选择器,时间选择器,日期选择器,多列选择器
前端·css·uni-app
一个处女座的程序猿O(∩_∩)O2 小时前
前端如何判断多个请求完毕
前端·javascript