vue打包成html不能用,Vue 打包的静态文件不能直接运行的原因及解决办法

问题

吾辈使用 vue-cli 直接生成的 vue 模板项目,在模板之上继续开发的。然而在使用 npm run build打包项目时,却发现打包好的项目在浏览器中直接打开好像什么都没有?

原因

查看了一下打包后的 index.html 源码,终于发现了一个重要的点:

45a9130ee6f9dd97dad4c790cf0e183e.png

所有涉及到路径的地方全都是以 / 开头的

下面是吾辈打包后生成的 dist 目录

dist:.

│ index.html

└─static

├─css

│ app.b7bce283257fbd427fb1dc3fea80cee1.css

│ app.b7bce283257fbd427fb1dc3fea80cee1.css.map

├─fonts

│ MaterialIcons-Regular.012cf6a.woff

│ MaterialIcons-Regular.570eb83.woff2

│ MaterialIcons-Regular.a37b0c0.ttf

│ MaterialIcons-Regular.e79bfd8.eot

└─js

app.58cce746b2fe4ac2f2b9.js

app.58cce746b2fe4ac2f2b9.js.map

manifest.2ae2e69a05c33dfc65f8.js

manifest.2ae2e69a05c33dfc65f8.js.map

vendor.a32972498ed8de656202.js

vendor.a32972498ed8de656202.js.map

这下很清楚了,vue-cli 生成的模板项目打包后的文件默认需要放到静态资源服务器上,而且还必须是根目录!这很不好,很糟糕,所以需要修改配置。

解决方案

修改文件 _/config/index.js_,将 build.assetsPublicPath 属性的值由 / 改为 ./

0a33a9879b90db62cce943454d602dcc.png

修改文件 _/build/utils.js_,在插件 ExtractTextPlugin 中添加 publicPath: '../../'

1ca4fbb4d9b8035ea1887ff6b4f812ce.png

那么,使用 npm run build 重新打包后的静态文件应该就可以直接打开啦

以上就是Vue 打包的静态文件不能直接运行的原因及解决办法的详细内容,更多关于vue 打包静态文件的资料请关注脚本之家其它相关文章!

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值