vue解决动态加载图片静态资源路径的问题

本文介绍了在Vue项目中使用v-for循环遍历显示图片时遇到的问题及解决方法。通过使用require函数正确引入静态资源图片,使得图片能够正常显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开发时遇到的问题,在使用v-for循环的时候,明明地址没有问题,但是依旧显示不出来图片

// html
<el-carousel-item v-for="(item, index) in imgSrc" :key="index">
    <img :src="item" />
</el-carousel-item>

// js
// @表示处于src文件夹下
 imgSrc:['@/assets/swiper/slide3.png',
        '@/assets/swiper/slide3.png',
        '@/assets/swiper/slide3.png',],

这样写的效果如下:

 图片显示不出来!

打开控制台查看静态资源,发现图片根本没有显示,预览是空的!

 网上查了不少资料,最后才发现,原来是我引入的问题,先上代码解决问题,再详细说明原因吧

// html
<el-carousel-item v-for="(item, index) in imgSrc" :key="index">
    <img :src="item" />
</el-carousel-item>

// js
// 静态资源图片需要用require引入
imgSrc: [require('@/assets/swiper/slide3.png'),
        require('@/assets/swiper/slide3.png'),
        require('@/assets/swiper/slide3.png'),],

 这样图片就出来了!

原因:

不用require引入,浏览器会直接显示 '@/assets/swiper/slide3.png' ,不经过编译的步骤,直接将获取到的数据当作字符串显示。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值