详解vue静态资源打包中的坑与解决方案


Posted in Javascript onFebruary 05, 2018

本文主要解决

①.vue-cli默认配置打包后部署至特定路径下静态资源路径错误问题;

②.静态资源打包使用相对路径后css文件引入大图片路径错误问题。

1、问题

vue-cli 脚手架生成的默认打包配置文件情况下运行 npm run build 打包后,部署项目至特定路径下:如:

//ip:port/public/springActivity/

此时访问:

http://ip:port/public/springActivity/index.html

index.html 可以正常访问,但是引用的js,css等文件服务器响应均为404,查看引入的资源路径如下:

http://ip:port/static/css/app.cea07642cd24c0d7a5c4b9b7afc7ff64.css
http://ip:port/static/js/app.815851e87b083afb82bf.js

2、分析

由上可以看出是资源打包路径有误,打包后的资源使用了绝对根目录路径,因此将项目部署到特定目录下,其引入的资源路径无法被正确解析。

3、解决

在打包时需要使用相对路径来处理静态资源,更改build中资源发布路径配置(config/index.js, build对象):

将 assetsPublicPath: '/'  改为  assetsPublicPath: './',
再次打包,并将资源部署到特定路径下,然后访问:

此时index.html可以正常访问,同时js和css资源也可以正常访问,但是css中引入的assets目录下的大图片资源出错了(服务端404)

4. 再分析

查看引入的图片资源路径如下:

http://ip:port/public/springActivity/static/css/static/img/question_bg.61a2825.png

实际项目中资源路径如下:

index.html
static/
 |--js/
  |--*.js
 |--css/
  |--*.css
 |--img/
  |--*.png

很明显图片引入路径有误。分析图片引入路径,发现路径均多了"/static/css"两层目录,猜测是css目录下的css文件引入图片路径为"/static/img/question_bg.61a2825.png" , 查看css文件,css中引入图片路径如下:

background:url(static/img/question_bg.61a2825.png)

5、在解决

css文件中路径存在问题,肯定又是打包哪个环节资源路径没有配置好,分析打包过程,css是在js中引入的或是写在vue文件中的,css文件首先被less,postcss等处理,处理后会被ExtractTextPlugin处理,ExtractTextPlugin将js中的css全部抽离至app.css文件中。

首先将options.extract设为false,关闭抽离css功能,再次打包并部署至特定目录,访问:http://ip:port/public/springActivity/index.html, 啪,页面正常显示,大公即将告成。

分析打包后的文件,发现没有了css文件,发现css文件全部在app.js文件中;通过js将css注入 index.html文件中,因此css文件中引入的图片资源路径应该是相对于index.html文件路径的,即:"static/img/question_bg.61a2825.png",这与下面css文件中的图片资源路径一致,因此图片能够被正常访问。

background:url(static/img/question_bg.61a2825.png)
现在很确定知道问题出在哪了,即:ExtractTextPlugin抽离css文件时没有转换资源引入路径,导致app.css引入了相对app.css目录为"static/img/ .png"的静态资源,该路径相对index.html即为:static/css/static/img/ .png。

因此使用ExtractTextPlugin插件时还需要配置静态资源路径参数,通过查询资料,得知可以通过添加publicPath:"../../"解决该问题:

if (options.extract) {
 return ExtractTextPlugin.extract({
 use: loaders,
 fallback: 'vue-style-loader',
 publicPath:"../../"     //添加
 })
}

打包部署到特定目录下后访问index.html文件,页面一切正常,app.css文件正常引入,图片资源也正常引入,查看app.css文件引入图片资源方式如下:

background:url(../../static/img/question_bg.61a2825.png

publicPath配置后,css文件中引入的图片文件路径前添加了该路径配置;

publicPath 属性值为打包后的 app.css文件至index.html文件的相对路径

图片资源也可以直接放在vue-cli生成的static目录下规避上述问题,但是通过这种方式图片名称中无法增加md5字符串,不利于版本控制

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
动态标签 悬停效果 延迟加载示例代码
Nov 21 Javascript
jquery 显示*天*时*分*秒实现时间计时器
May 07 Javascript
jquery实现TAB选项卡鼠标经过带延迟效果的方法
Jul 27 Javascript
jQuery常用样式操作实例分析(获取、设置、追加、删除、判断等)
Sep 08 Javascript
JavaScript判断浏览器对CSS3属性是否支持的多种方法
Nov 13 Javascript
javascript+html5+css3自定义弹出窗口效果
Oct 26 Javascript
深入剖析Node.js cluster模块
May 23 Javascript
不得不知的ES6小技巧
Jul 28 Javascript
JS/HTML5游戏常用算法之追踪算法实例详解
Dec 12 Javascript
Node对CommonJS的模块规范
Nov 06 Javascript
vue实现动态表格提交参数动态生成控件的操作
Nov 09 Javascript
Java无向树分析 实现最小高度树
Apr 09 Javascript
理解Koa2中的async&await的用法
Feb 05 #Javascript
zTree 树插件实现全国五级地区点击后加载的示例
Feb 05 #Javascript
使用vue如何构建一个自动建站项目
Feb 05 #Javascript
在 webpack 中使用 ECharts的实例详解
Feb 05 #Javascript
在Vue中使用echarts的方法
Feb 05 #Javascript
JavaScript中Object基础内部方法图
Feb 05 #Javascript
基于axios封装fetch方法及调用实例
Feb 05 #Javascript
You might like
PHP的变量总结 新手推荐
2011/04/18 PHP
探讨php中header的用法详解
2013/06/07 PHP
PHP文件与目录操作示例
2016/12/24 PHP
jquery事件与函数的使用介绍
2013/09/29 Javascript
JSON与XML优缺点对比分析
2015/07/17 Javascript
jquery实现平滑的二级下拉菜单效果
2015/08/26 Javascript
jQuery链式操作实例分析
2015/11/16 Javascript
JS+CSS实现DIV层的展开、收缩效果
2016/01/28 Javascript
sea.js常用的api简易文档
2016/11/15 Javascript
JS中Attr的用法详解
2017/10/09 Javascript
vue移动端UI框架实现QQ侧边菜单组件
2018/03/09 Javascript
vue2.0+ 从插件开发到npm发布的示例代码
2018/04/28 Javascript
JS的函数调用栈stack size的计算方法
2018/06/24 Javascript
详解nuxt sass全局变量(公共scss解决方案)
2018/06/27 Javascript
详解webpack4.x之搭建前端开发环境
2019/03/28 Javascript
vue路由守卫+登录态管理实例分析
2019/05/21 Javascript
JS获取动态添加元素的方法详解
2019/07/31 Javascript
js中addEventListener()与removeEventListener()用法案例分析
2020/03/02 Javascript
pyQt4实现俄罗斯方块游戏
2018/06/26 Python
python实现小球弹跳效果
2019/05/10 Python
Python3 串口接收与发送16进制数据包的实例
2019/06/12 Python
python协程gevent案例 爬取斗鱼图片过程解析
2019/08/27 Python
python opencv调用笔记本摄像头
2019/08/28 Python
python画环形图的方法
2020/03/25 Python
Pycharm配置lua编译环境过程图解
2020/11/28 Python
html5基础标签(html5视频标签 html5新标签用法)
2013/12/30 HTML / CSS
美国孩之宝玩具官网:Hasbro Pulse
2019/06/24 全球购物
您的时尚,您的生活方式:DTLR Villa
2019/12/25 全球购物
中专生自我鉴定范文
2014/02/02 职场文书
2014国庆节餐厅促销活动策划方案
2014/09/16 职场文书
无犯罪记录证明
2014/09/19 职场文书
民主生活会发言材料
2014/10/20 职场文书
关于开学的感想
2015/08/10 职场文书
员工升职自我评价
2019/03/26 职场文书
CSS实现多个元素在盒子内两端对齐效果
2021/03/30 HTML / CSS
告别网页搜索!教你用python实现一款属于自己的翻译词典软件
2021/06/03 Python