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后找不到静态资源的问题


捕获.JPG

—————————————————————————————————

以下为发现问题过程,以及问题分析过程

项目当中,路由模式不设置时,默认的是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后找不到静态资源的问题

捕获.JPG

你可能感兴趣的:(vue路由在多级页面下,页面刷新空白(history模式))