Vue项目动态加载图片正确写法

教程下载地址: 网赚博客https://www.piaodoo.com/创业项目排行榜前十名https://www.piaodoo.com/


1. 错误的写法

以下情况运行异常,图片加载不出来

<img class="img" :src="imgSrc" />
<script>
let imgSrc = '../../assets/img1.png';
</script>

2. 正确的实践写法

方法 1

这时候需要换个写法,让编译时把图片加上去一起处理

原因:编译时webpack会将图片当成模块加载使用。然而上面第 1 点是动态的,loader无法解析图片路径,所以编译规则处理不了,所以加载时会找不到图片。

<img class="img" :src="imgSrc" />

<script>
import img1 from ‘…/…/assets/img1.png’
let imgSrc = img1;
</script>

方法2

把图片资源放到静态目录下static,引用的时候就直接是固定地址进行引用

assets 和 static 的区别:
assets:在项目编译的过程会被webpack处理解析为模块依赖,只支持相对路径的形式。
static:在static这个目录下文件不会被webpack处理和解析,webpack直接复制到最终的打包目录dist/static。必须使用绝对路径引用这些文件。

<img src="/static/img1.png" />

附:vue中动态加载图片路径

        在vue中加载图片路径跟我们不用框架引入路径是不同,在页面中使用的话,写的路径是可以生效的,但是我们想动态加载图片路径的话是不生效的。

这里有两种方法来解决:

方法一:(推荐)

1、页面上,绑定动态路径:

<img :src=" imgUrl "/> 

2、data里面:用   require(图片路径)

 data(){
      return{
        imgUrl:require('@/assets/img/mind/mind_5.svg');
    }
}

方法二:

把图片放到static,然后相对路径获取图片就好了

src: '../../../../static/images/docx.png'

总结 

到此这篇关于Vue项目动态加载图片正确写法的文章就介绍到这了,更多相关Vue动态加载图片内容请搜索网赚博客https://www.piaodoo.com/以前的文章或继续浏览下面的相关文章希望大家以后多多支持网赚博客https://www.piaodoo.com/!

                        友情连接:  

茂名一技http://www.szsyby.net/


茂名一技http://www.enechn.com/


美文集http://www.tpyjn.cn/


手游排行前十名http://www.bjkhrx.com/


蔚来汽车http://www.weilaiqiche.cn/

### Vue3 中动态绑定图片的实现方法 在 Vue3 中,为了确保图片路径能够在不同环境中正常解析并加载,推荐采用函数方式来动态绑定 `img` 标签的 `src` 属性。这种方式不仅解决了开发环境与生产环境之间的路径差异问题,还提高了代码的可维护性和灵活性。 对于图片资源的引入,应当注意区分相对路径和模块路径的区别。直接使用类似于 `'@/asset/image/xxx.png'` 的写法,在某些情况下可能会导致构建工具无法正确识别资源位置[^2]。 #### 正确的做法如下: 通过定义一个辅助函数 `getImageUrl()` 来获取图片的真实URL地址,并将其返回值赋给 `img` 组件的 `src` 属性。此方法利用了 JavaScript 模块系统的特性,能够兼容 Webpack 或 Vite 等现代前端构建工具的工作机制。 ```html <template> <div> <!-- 使用 getImageUrl 函数传递参数 --> <img :src="getImageUrl(imagePath)" alt="example image"/> </div> </template> <script setup> import { ref } from 'vue'; // 定义图像文件名变量 const imagePath = ref('xxx.png'); /** * 获取指定路径下图片的实际 URL 地址 */ function getImageUrl(path) { return new URL(`/src/assets/images/${path}`, import.meta.url).href; } </script> ``` 上述代码片段展示了如何创建一个名为 `getImageUrl` 的函数用于处理图片路径转换逻辑。这里的关键在于调用了 `new URL()` 构造器配合模板字符串拼接出完整的静态资源访问链接,同时借助于 `import.meta.url` 提供当前模块的位置信息作为基础URI。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值