Vue 通过 v-bind 绑定图片src的两种方式

前提声明

这个问题的解决是在vue-cli3下,因为问候提到的public文件夹是3版本产生的

在学习vue时,有一个需求是需要 v-for 循环图片,之后用一个图片地址数组通过(v-bind)去绑定图片的src,这个地方有一个大坑


错误写法

//错误写法
<div id='app'>
	<!-- 通过v-for循环遍历data中的地址 并绑定 -->
	<img v-for="(mysrc, index) in srcs" :key="index" :src="mysrc">
</div>
var app = new Vue({
 el : '#app',
 data : {
 srcs: ['相对地址一','相对地址二']
}) 

错误原因

这种写法主要错在data里面的 srcs的地址,在通过v-for循环绑定图片的src的时候,vue会把相对地址解析为一个字符串,而非一个地址这就导致图片无法加载

解决方式

  1. 把图片放入 vue-cli3 自动生成的public下,不用src中的相对路径。
    mysrc:[’…/’…/assets/img1.png,’…/…/assets/img2.png’]
    改为
    mysrc:[‘images/img.png’,‘images/img.png’]

    vue-cli3默认路径为public,所有无需添加public。images是我手受添加到public的文件夹


  2. 使用 require方法返回的绝对地址。如果一定要用src相对路径方式,给路径前加上** require() ** 方法。
    mysrc:[’…/’…/assets/img1.png,’…/…/assets/img2.png’]
    改为
    mysrc:[require(’…/’…/assets/img1.png’),require(’…/…/assets/img2.png’)]

注意事项

在使用第二种方法时,require() 内部只能写入 字符串常量,无法写入变量,所以想要通过存字符串变量数组的话,变量的值需要是public的路径才可以

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值