解决方法:

老方法: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 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐