vue路由在多级页面下,页面刷新空白(history模式)
vue路由在多级页面下,页面刷新空白(history模式)
·
解决方法:
老方法: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后找不到静态资源的问题
更多推荐
已为社区贡献7条内容
所有评论(0)