vue中使用require动态获取图片地址

项目场景:

项目中根据图片不同的后缀名,展示不同的图片


问题描述

直接给图片的src绑定图片地址,图片不显示,使用 require('图片本地路径' + '地址变量' + '.png') 也不显示

	<img :src="require('@/assets/img/' + item.url + '.png')" alt="" />

原因分析:

vueDOM中直接引入的图片会被转为base64格式,但是使用变量引入的话,图片不会转为base64,所以不显示
在这里插入图片描述


解决方案:

使用require.context实现前端工程化引入文件

require.context(directory, useSubdirectories, regExp)

  • directory 检索的目录
  • useSubdirectories : 是否检索子文件夹
  • regExp: 匹配文件的正则表达式,一般是文件名
  • mode: 加载模式。同步还是异步

require.context 执行后,返回一个方法 webpackContext,这个方法又返回一个 __webpack_require__ , 这个 __webpack_require__ 相当于require或者import。同时webpackContext还有第二个静态方法 keysresolve,一个id属性

  1. keys:返回匹配成功模块的名字组成的数组
  2. resolve:接受一个参数requestrequesttest文件夹下面匹配文件的相对路径,返回这个匹配文件相对于整个工程的相对路径
  3. id:执行环境的id,返回的是一个字符串,只要用在module.hot.accpet,应该是热加载

主要代码

	const images = require.context("@/assets/test", false, /\.png$/);
        let imageURL = ''
        images.keys().forEach(key => {
          const name = path.basename(key, '.png')
          if (name === 图片后缀名) {
            imageURL = images(key).default || images(key)
          }
        })
        return imageURL;
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值