时间:2021-04-08 10:40:10 | 栏目:vue | 点击:次
最近遇到了个问题,用v-bind动态绑定img的src,图片加载不出来。控制台显示src是有获取到图片地址的,可是就是加载不出来。
最后才发现原因原来是浏览器中直接显示'./img/img1.png',也就是没有经过编译的步骤,直接将获取到的数据当作字符串显示。
解决方法:
1.在当前界面全局import图片地址
//使用import引入 import img1 from './img/img1.png' import img2 from './img/img2.png' export default { data() { return { imgList[ { id: 0, imgUrl: img1 }, { id: 1, imgUrl: img2 } ] } } }
在Html中使用
<img v-for="item in imgList" :key="item.id" :src="imgUrl" />
2.使用require
用第一种方法可能会很繁琐,数据多的时候就不好一个一个import了,此时用require动态加载
getImage() { this.imgList.forEach(item => { item.imgUrl = require('./img/' + item.name + '.png') }) }
data里的数据(此方法就不用再import啦)
data() { return { imgList[ { id: 0, name: 'img1', imgUrl: '' }, { id: 1, name: 'img2', imgUrl: '' } ] } }
以上方法就可以解决图片动态绑定后不能显示的问题啦,视频同理哟!
总结