继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

vue项目打包后资源路径与背景图路径问题

慕哥9229398
关注TA
已关注
手记 1099
粉丝 199
获赞 913
本文主要解决基于vue/vuex打包后经常出现的两个问题:
  • 静态资源路径错位问题

  • css背景图路径错位问题


  • 问题的出现:
    一般通过vue-cli脚手架开发的时候,开发模式使用npm run dev进行开发,一切配置正常。但是当打包后会出现各种问题,其中两个最为常见且致命的问题莫过于上述的两个资源路径错位问题,但是当我们分析后,发现依旧是配置问题。尤其是当好多猿把assetsPublicPath: '/''/'改为'./'后,一般的资源路径包括css、js、图片音视频等都能校正,然而唯独css设置的背景图却全部失效。接下来请看此bug图。


  • bug图:

1. 资源路径404

webp

资源路径404.png


2. 背景图路径404

webp

背景图404.jpg


可以看到背景图的路径错且重复。



  • 解决方案:

1. 静态资源路径错位问题解决方案:
项目/config/index.js中找到module.exports中的build,其中的assetsPublicPath项改为:

assetsPublicPath: './', //解决静态资源路径错位问题

2. css背景图路径错位问题解决方案:
项目/build/utils.js中找到ExtractTextPlugin.extract,追加publicPath: '../../'
代码片段为:

return ExtractTextPlugin.extract({            use: loaders,
            fallback: 'vue-style-loader',
            publicPath: '../../'  //解决css背景图路径错位问题
      })

  • 测试结果:
    ok,配置完毕,打包测试下~
    npm run build 倒数10个数:10,9,8,7,6...
    控制台空空如也~完美!

    webp

    完美解决.png



作者:流眸Tel
链接:https://www.jianshu.com/p/23f6aeb26083


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP