动态绑定图片

本文详细介绍了在Vue项目中加载图片的三种常见方法:使用require动态加载、使用import静态引入以及通过绝对路径访问静态资源目录。每种方法都有其适用场景和优缺点,帮助开发者根据项目需求选择最适合的图片加载策略。

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

1、使用require,在不调整目录结构的情况下读取图片
缺点:由于common.js只允许使用字符串字面量,故不利于组件化,灵活性较差

<template>
  <div id="app">   
      <img :src="url1" alt="图片1">
      <img :src="url2" alt="图片2">
  </div>
</template>

我们的图片要用require引进来,静态资源都要用require引入

 data(){
    return{
      url1:require('../images/one.jpg'),
      url2:require('../images/two.jpg')
    }
 }

2、使用import引入

<script>
import logo  from './images/logo.jpg'
export default {
    data(){
        return{
        src:logo
        }
    }
   </script>

3、绝对路径访问
把图片放到静态资源目录static目录下(build会将static目录中的文件或文件夹按照原本的结构放在dist目录下),并用、static绝对路径访问

<template>
  <div id="app">   
      <img :src="src" alt="图片1">  
  </div>
</template>
 data(){
    return{
      src:`/static/images/logo.jpg`     //反引号
    }
 }
### 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、付费专栏及课程。

余额充值