过程:在网上参考了很多处理的方式,有修改meta的、路由加参数的、动态添加时间戳的。尝试过后发现针对我现有的问题而言,没有很好的解决,以下做一个记录
解决:
①:打包后的index.html中,给js文件加后缀
②:初始文件加时间戳
系统bug。vue项目大多数是系统bug导致的。解决方案如下:1首先修改根目录index.html在head里面添加下面代码12这种会让所有的css/js资源重新加载。
2最后配置nginx不缓存htmlvue默认配置,打包后css和js的名字添加哈希值。
1.问题描述
在项目开发中,当我们通过npm run build打包之后将文件放在服务器上时通常会出现图片失效问题,控制台中提示某个图片没有找到(404错误),这些图片可以是以src引入的图片, 也可以是css中定义的背景图片。图片能否显示与你的静态资源文件存在位置和引入
的路径直接相关,下面是我的其中一个项目的文件存放以及路径书写方式!
2.解决方法之一
静态资源static存放位置放在src目录下
你可能会问为什么放在src目录下?放在跟src同级目录下不可以吗?好吧,一开始我也是放在src同级目录下,但是在某个css文件中引入背景图片的时候打包之后图片失效,我是这样引入的
实践证明这个写法是错误的,这个会在你打包的时候直接抱一大堆错(如css-loader错误),连项目都跑不起来。
于是我用下面的写法:
这种写法也是不可以的,原因是你的静态资源文件static不在src目录,而在vue中src目录是相对根目录是src目录,所以如果你想用上面的写法,必须要把static放在src目录下。如上面图一图二
注意:不能把static/images/user.png写成 /static/images/user.png,否则图片还是失效。
以上是关于文件存放位置以及css中引入图片问题,如果是通过img标签引入图片的话,相对简单,直接写绝对地址就行了,并且静态资源static文件夹的位置可以在src里面,也可以放在与src同级下,但是为了不出现上面情况,放在src里面即可!
img引入图片:
以上是一种解决图片失效问题的方法,当然,如果非要把static静态资源目录放在与src同级目录下,也是有解决方法,例如通过导入图片的方式(本人未实践),可以自行尝试!