做聊天表情时,表情图片放在assets目录中,读取数组动态显示图片时发现图片显示不出来

4 篇文章 0 订阅

问题描述:做聊天表情时,表情图片放在assets目录中,读取数组动态显示图片时发现图片显示不出来,但是如果是在src=""这里是写死的字符串是能显示的

如下图:第一个img可以显示,第二个不行(变量的路径是没错的,一样的路径)

<div class="face-item" v-for="(item,index) in emotionList" @click="clickEmoticon(item.src, item.sign)" :key="index" :title="item.desc">
	<img src="../assets/images/logo.png">
	<img :src="item.src">
</div>

问题:发现是assets目录下的图片,需要使用require()进行包裹的处理的,于是如下:

<img :name="item.desc" :src="require('../assets/images/logo.png')">

发现还是不行,这里没想明白,后来百度发现说require中不能用变量,只能是字符串。。。,很难受。

这里尝试了2种办法可以:

法一:在定义数组变量这里就用require包裹(require(xx)返回的值是一个base64的数值),然后页面显示直接不变,用:src="item.src"

let EMOTION_LIST = [
  {
    "src": require("../assets/images/emoji/0000.gif"),
    "sign": "[emoji_0000.gif]"
  },
  {
    "src": require("../assets/images/emoji/0001.gif"),
    "sign": "[emoji_0001.gif]"
  }
]

法二:数组对象中只留了文件名,把前面的路径和后缀都剪掉了,然后在拼接起来,不知道这样为什么就可以,反正是能正常显示的

<img :src="getSrc(item.src)">
......
methods: {
    getSrc(src){
        return "../assets/images/emoji/" + src + ".gif"
    }
}
let EMOTION_LIST = [
  {
    "src": "0000",
    "sign": "[emoji_0000.gif]"
  },
  {
    "src": "0001",
    "sign": "[emoji_0001.gif]"
  }
]

记录一下~

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值