Vue动态设置img的src不生效的问题

在Vue项目中,动态设置img的src可能导致图片加载失败,原因是src被当作静态资源处理。解决方法是使用require引入图片,确保图片在运行时能够正确加载。此外,解释了require(运行时加载)和import(编译时加载)的区别,import适用于提前导入资源,require遵循CommonJS/AMD规范,而import遵循ESMAScript 6+规范。

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

原因分析

在vue项目中动态设置img的src时,图片会加载失败。我们可以先看个例子。

<template>
  <div>
    <h1>动态设置图片</h1>
    <div>
      <h5>图片一</h5>
      <img
        :src="
          logoFlag === 'vue'
            ? '../assets/vue-logo.png'
            : '../assets/react-logo.png'
        "
      />
      <div>
        <button @click="changeLogo">切换</button>
      </div>
      <h5>图片二</h5>
      <img :src="imgUrl" />
    </div>
  </div>
</template>
<script>
export default {
  name: "ImgTest",
  data() {
    return {
      logoFlag: "vue",
      imgUrl: "../assets/vue-logo.png",
    };
  },
  methods: {
    changeLogo() {
      this.logoFlag = this.logoFlag === "vue" ? "react" : "vue";
    },
  },
};
</script>
<style scoped>
img {
  width: 50px;
  height: 50px;
}
</style>

由结果可以看出图片加载失败。

查看elements之后会发现,src被当做静态资源处理了,并没有进行编译。

解决方法

 为了解决动态的src没有进行编译的问题,我们可以使用require引入图片。

<template>
  <div>
    <h1>动态设置图片</h1>
    <div>
      <h5>图片一</h5>
      <img
        :src="
          logoFlag === 'vue'
            ? require('../assets/vue-logo.png')
            : require('../assets/react-logo.png')
        "
      />
      <div>
        <button @click="changeLogo">切换</button>
      </div>
      <h5>图片二</h5>
      <img :src="imgUrl" />
    </div>
  </div>
</template>
<script>
export default {
  name: "ImgTest",
  data() {
    return {
      logoFlag: "vue",
      imgUrl: require("../assets/vue-logo.png"),
    };
  },
  methods: {
    changeLogo() {
      this.logoFlag = this.logoFlag === "vue" ? "react" : "vue";
    },
  },
};
</script>
<style scoped>
img {
  width: 50px;
  height: 50px;
}
</style>

 

可以看到使用require引入图片之后,图片就可以正常加载出来了。

import和require的区别

require是在运行时加载,而import是编译时加载;

如果希望使用import引入图片就需要提前导入图片。

<template>
  <div>
    <h1>动态设置图片</h1>
    <div>
      <h5>图片一</h5>
      <img
        :src="
          logoFlag === 'vue'
            ? require('../assets/vue-logo.png')
            : require('../assets/react-logo.png')
        "
      />
      <div>
        <button @click="changeLogo">切换</button>
      </div>
      <h5>图片二</h5>
      <img :src="imgUrl" />
    </div>
  </div>
</template>
<script>
import reactLogo from "../assets/react-logo.png";

export default {
  name: "ImgTest",
  data() {
    return {
      logoFlag: "vue",
      imgUrl:reactLogo,
    };
  },
  methods: {
    changeLogo() {
      this.logoFlag = this.logoFlag === "vue" ? "react" : "vue";
    },
  },
};
</script>
<style scoped>
img {
  width: 50px;
  height: 50px;
}
</style>

 

另外require和import另外的区别:

require是CommonJs/AMD规范,而import是ESMAScript6+规范。 

### Vue 组件引入不生效的原因分析 当遇到 Vue 组件引入后未按预期工作的情况时,可能涉及多个方面的问题。以下是几种常见原因及其对应的解决方案: #### 版本兼容性问题 如果使用的组件库版本过低或过高,可能会导致与当前项目的框架版本存在兼容性问题[^1]。建议检查并更新至官方推荐的最新稳定版。 #### 样式作用域冲突 对于带有 `scoped` 属性的 `<style>` 标签,在某些情况下可能导致子组件样式未能正确应用到父级或其他兄弟节点上[^2]。移除该属性或将特定的选择器添加到全局范围可以解决问题。 #### 资源路径配置错误 资源文件(如图片、字体等)加载失败通常是因为相对路径设置当所致[^4]。采用绝对路径或者通过 Webpack 别名来指定位置能有效规避此类失误。 #### 全局样式注册失效 尝试在入口文件(main.js)里统一导入自定义样式的做法有时会因为构建工具链的同而遭遇阻碍[^3]。确认预处理器是否已被正确安装以及其配置项是否合理十分必要。 针对上述提到的各种情形,下面给出具体的排查步骤和技术实现方法: ```javascript // 更新依赖包以确保最佳适配度 npm install iview@latest --save // 或者对应其他第三方UI库名称 ``` ```css /* 移动 scoped 属性 */ <style> /* 这里的 CSS 将应用于整个应用程序 */ </style> <!-- 如果确实需要局部样式,则考虑使用深度选择符 --> <style scoped> >>> .child-component-class { color: red; } </style> ``` ```html <template> <!-- 使用别名访问静态资源 --> <img :src="require('@/assets/logo.png')" alt="Logo"> <!-- Vite环境下处理媒体素材 --> <img src="@/assets/MicrosoftWord.png" /> </template> <script setup lang="ts"> import { ref } from 'vue'; const wordImg = new URL('/src/assets/MicsosoftWord.png', import.meta.url).href; </script> ``` ```scss // 确认 Stylus 插件已加入 webpack 配置中 module.exports = { css: { loaderOptions: { stylus: { preferPathResolver: 'webpack' } } } }; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值