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

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值