vue路由在多级页面下,页面刷新空白(history模式)
vue
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
项目地址:https://gitcode.com/gh_mirrors/vu/vue
免费下载资源
·
解决方法:
老方法:cli2
需要修改config/index.js文件,将assetsPublicPath的值改为assetsPublicPath: './'
老方法2:cli3
找到项目文件下的vue.config.js(没有就自己创建一个),将baseUrl:""改成baseUrl:"/"
新方法:cli3.0以上
找到项目文件下的vue.config.js(没有就自己创建一个),配置publicPath: '/', // 根路径 cli3.0以上使用publicPath替代baseUrl,解决build后找不到静态资源的问题
—————————————————————————————————
以下为发现问题过程,以及问题分析过程
项目当中,路由模式不设置时,默认的是hash。
而设置history后,一级路由刷新页面不会报错,而二级以上路由,会出现这么一个问题,
Uncaught SyntaxError: Unexpected token ‘<‘
提示:
报错.JPG
这时候,我们点击错误,发现问题出现在public中的index.html中,
报错.JPG
首先,我们可以排除是vue原页面的问题,
我们每次刷新页面的前打开浏览器的network,我们再刷新,然后会发现,js请求的位置不对,
// 例如 在一级路由aaa中
// 我们请求app.js位置
aaa/static/app.js
// 这个时候静态资源存在
//而在二级路由aaa/bbb中,请求地址会变成
aaa/bbb/static/app.js
// 这就导致了我们请求不到页面的静态资源
原因:
在history模式中,请求多级路由下的静态资源,会带上多级路由的地址
解决方法:
找到项目文件下的vue.config.js(没有就自己创建一个),配置publicPath: '/', // 根路径 cli3.0以上使用publicPath替代baseUrl,解决build后找不到静态资源的问题
GitHub 加速计划 / vu / vue
207.54 K
33.66 K
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:2 个月前 )
73486cb5
* chore: fix link broken
Signed-off-by: snoppy <michaleli@foxmail.com>
* Update packages/template-compiler/README.md [skip ci]
---------
Signed-off-by: snoppy <michaleli@foxmail.com>
Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 4 个月前
e428d891
Updated Browser Compatibility reference. The previous currently returns HTTP 404. 5 个月前
更多推荐
已为社区贡献3条内容
所有评论(0)