IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue项目中img的src动态加载问题 -> 正文阅读

[JavaScript知识库]Vue项目中img的src动态加载问题

利用vue做轮播图的时候,我将一些图片存在本地assets文件,在data中直接写成下面这样:

imgList:['../assets/1.png','../assets/2.png''../assets/3.png']

运行代码时图片时无法正常显示的。

原因:webpack会将图片当模块使用。但是因为上面图片是动态加载的,所以url-loader无法解析图片路径,执行npm run dev或者npm run build之后导致路径没有被加工。

动态和非动态引入图片时浏览器中路径的区别:

imgPath='../assets/2.png'
<!-- 动态加载,url-loader无法解析路径地址,不会处理路径,图片显示失败-->
<!-- 浏览器对应DOM:<img data-v-e3565ce0="" src="../assets/2.png" class="img"> -->
	<img class="img" :src="imgPath" />

<!-- 非动态加载,webpack会自动对路径进行处理,图片显示成功 -->
<!-- 浏览器对应DOM:<img data-v-e3565ce0="" src="/static/img/2.b3117e2.png"> -->
      <img src='../assets/2.png' />

解决思路:将图片作为模块加载进去,这样webpack将能将它解析,或者将资源放在static目录下。

解决方法1:通过import导入。

<script>
import img1 from '../assets/1.png'
import img2 from '../assets/2.png'
import img3 from '../assets/3.png'

export default {
  data () {
    return {
      imgList: [
        img1, img2, img3
      ]
    }
  }
}
</script>

解决方法2:通过require。

<script>
export default {
  data () {
    return {
      imgList: [
        require('../assets/1.png'),
        require('../assets/2.png'),
        require('../assets/3.png')
      ]
    }
  }
}
</script>

解决方法3:将图片放到static目录下,写成绝对路径的形式。

 imgList: ['/static/1.png', '/static/2.png']

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

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-10 22:22:38  更:2022-03-10 22:26:49 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 7:30:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码