
解决Vue打包后放到部署到服务器运行时出现Loading chunk * failed 错误
原因:路由懒加载的情况下,访问当前应用进行路由跳转时都是实时动态的从服务器上拉取相应模块的js文件,这时候我们改完代码打包上线,js文件名更换了,路由跳转的时候由于页面并未刷新,所以还是访问的原来的文件名,这是就会出现找不到模块的错误。 路由异步加载组件报错,这个错误来源 webpack 进行 code spilt 之后某些 bundle 文件 lazy loading 失败
发布日期:2021-05-10 23:43:28
浏览次数:13
分类:精选文章
本文共 699 字,大约阅读时间需要 2 分钟。
最近一直在捣鼓的Springboot+Vue 前后端分离项目,Vue 前端项目打包部署到Nginx 服务器访问时,点击导航栏切换一直报错:

解决方案:
- 让错误在一个路由守卫函数中被同步抛出;
- 让错误在一个路由守卫函数中通过调用 next(err) 的方式异步捕获并处理;
- 渲染一个路由的过程中,尝试解析一个异步组件时发生错误时,重新渲染目标页面,并将异步组件改为同步组件。
在src
目录下的permission.js
加入router.onError 进行处理:
渲染一个路由的过程中,尝试解析一个异步组件时发生错误时,重新渲染目标页面
router.onError(error => { const pattern = /Loading chunk (\w)+ failed/g const isError = error.message.match(pattern) const targetPath = router.history.pending.fullPath if (isError) { router.replace(targetPath) }})
发表评论
最新留言
留言是一种美德,欢迎回访!
[***.207.175.100]2025年04月06日 00时55分32秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Laravel8.x+Vue+AntDesign智慧医疗台管理系统框架
2021-05-11
基于Laravel8.x+Vue+AntDesign社会团购后台管理系统源码
2021-05-11
springboot(9)——员工管理系统之登录功能的实现
2021-05-11
请你谈谈Redis主从复制的理解?
2021-05-11
请你谈谈Redis缓存穿透和雪崩?
2021-05-11
请你谈谈IP的理解?
2021-05-11
请你谈谈http状态码、http 请求包含哪几个部分?
2021-05-11
请你谈谈AOP的基本认识?
2021-05-11
请你谈谈explain执行计划的理解?
2021-05-11
基于xml文件的spring事务配置管理
2021-05-11
单链表的基本操作
2021-05-11
方法的重载
2021-05-11
Java:2的个数
2021-05-11
链表面试题(7)
2021-05-11
寻找第K大
2021-05-11