build vue 静态化_vue动态定义图片路径

本文介绍了在Vue中动态设置图片路径遇到的问题及解决方案。通过分析webpack打包过程,发现动态定义图片路径会导致图片加载失败。提出了三种解决办法:1) 使用绝对路径访问静态资源目录下的图片;2) 使用require动态引入图片;3) 使用import导入图片路径。这些方法可以帮助开发者正确处理Vue项目中的图片路径问题。
摘要由CSDN通过智能技术生成

8a87a47f05af782a1ed1e4c1c6d9be23.png

来源 | https://www.jianshu.com/p/fab484498e4e

最近在使用vue动态设置图片路径的时候遇到了一些问题,特此整理。

我想实现的效果:点击图片,弹出系统图片选择框,选择图片后替换原图片。

App.vue中:

结果:

c25cd4f7ba1cd94125efcacf3b36fa83.png

默认图片加载成功,点击该图片可以弹出图片选择框。

本着组件抽象的原则,我想把上述代码抽象成组件,并且希望默认的图片url可以在父组件指定,于是,我这样写:App.vue:

import ItemShow_imageChoose from "./components/ItemShow-imageChoose"export default {name:'App',components: {"ItemShow-imageChoose":ItemShow_imageChoose } }

./components/ItemShow-imageChoose.vue:

export default{name:'ItemShow_imageChoose',props:{"id":[String],"imageSrc":[String] },methods:{ chooseFile(e){// this.$emit('choose',e.target.files) } } }

结果:

d7b0ab8b3f3e19b285f688b052785cc6.png

默认图片没有加载出来。

开始一步步找错....

首先,把图片的src移至子组件的data中,看图片是否能加载出来:

./components/ItemShow-imageChoose.vue:

export default{name:'ItemShow_imageChoose',props:{"id":[String],"imageSrc":[String] }, data(){return {src:'../assets/user.png' //重点看这里 } },methods:{ chooseFile(e){// this.$emit('choose',e.target.files) } } }

结果:

d7b0ab8b3f3e19b285f688b052785cc6.png

本来以为这样写肯定是对的,结果竟然不对,但是这个结果也说明:问题不是出在父子组件的参数传递上。

于是开始查资料....

看了一些文章和问答,也大致理解了出错的原因(参考文章见附录),是图片路径的问题。

如果图片地址是直接写死在html或者css里的,webpack会帮你处理这个图片最终的地址(要用到url-loader),例如:初始:

webpack编译后会变成:

实测:

打包成绝对路径:

b1eca73569866ed6865bd4a681351592.png

打包成base64字符串:

e1d3fa5d1bbea9f140a495baea3c97a3.png

项目目录:

8e82121c5047508c6e024bc7e41645da.png

以上就是webpack打包的两种方式,我们重点看第一种。第一种方式,图片是以绝对路径(以/开头的路径就是绝对路径,/指根目录,根目录在本地就是指磁盘,在github上就是指仓库的根目录,在网站上就是指服务器的根目录)进行查找,图片的目录为/static/img,但是我们查看上图项目目录,发现static目录下并没有img目录,也没有图片,那么这里的路径是怎么来的呢?

运行npm run build,再看一下项目目录:

2a76074f030ee806df78c04865e71402.png

我们在dist目录下面找到了该图片。由此知道,webpack打包后,会将静态资源文件放在dist/static/img下,我们的网站实际上以dist目录作为根目录,并由此加载该目录下的index.html所需的css、js、img等

现在我们使用Vue.js来动态定义图片路径:

export default{ data(){return {src:`../assets/user.png` } } }

结果:

a24e07c249f47fd65f9765fd094389cb.png

dist目录为根目录,index.html的路径为“./index.html”,那“../assets/user.png”即为与dist目录平级的assets目录下面的user.png,我们发现该目录不存在,图片自然加载失败。

当Vue.js来动态定义图片路径的时候,url-loader是无法探测到图片路径的。我们build后发现,图片根本不会打包输出到dist目录(webpack是按需打包的):

ffccf50496cb6e695f32a76133c739ec.png

由上图可知,dist目录下无图片文件或文件夹。

如何解决?

我整理并测试了以下三种解决办法:

1、绝对路径访问

把图片放到静态资源目录static目录下(build 会将static目录中的文件或者文件夹按照原本的结构放在dist目录下),并用/static绝对路径访问:

export default{ data(){return {src:`/static/img/user.png` } } }

结果:

0ba9c7e74ac1713ae48f7c4fc8dc53be.png

2、使用require

如果想在不调整目录结构的情况下读取图片,还可以使用require:

data(){return { src:require('../assets/user.png') //重点看这里 }}

dffb7bc8fc4332523deee4d94c02e679.png

该结果与上面说的webpack打包的第一种方式结果相同。

缺点:由于CommonJS只允许使用字符串字面量,所以不利于组件化,灵活性较差。

3、使用import

也可以用import引入图片路径:

import userPath from '../assets/user.png'export default{ data(){return {src:userPath } } }

结果:

b1a798ffa84e0c91049ac6487980cfd2.png

该结果与上面说的webpack打包的第一种方式结果相同。

就先整理到这里。多花些时间踩踩坑也是很好的,学到了就是赚到了。由于个人水平有限,错误之处,烦请指正!

附完整代码

./components/ItemShow-imageChoose.vue:

export default{name:'ItemShow_imageChoose',props:{"id":[String],"imageSrc":[String] },methods:{ chooseFile(e){var currentImg=e.target.nextElementSibling.childNodes[0] currentImg.setAttribute('src',window.URL.createObjectURL(e.target.files[0])) currentImg.onload=function () {window.URL.revokeObjectURL(this.src) } } } }

参考:1、Vue中img的src属性绑定与static文件夹2、问:vue+webpack动态设置图片src导致404错误

0705c91b381dc8ac0ad983f5d367cf7d.png

256b4941c9f97ef9de4bb1895b920f63.png

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值