Vue3+Vite中不支持require的方式引入本地图片如何解决

使用vue2+webpack的时候是用require引入图片

require(`../assets/${img}.png`)

但是vue3+vite这么写就报错:require is not define

原因是require是webpack的方法vite找不到对应的图片路径,需要使用下面的方式进行处理。

详细见官网解释:

静态资源处理 {#static-asset-handling} | Vite中文网


使用vite也有两种引入静态文件方法:

第一种 :

import imageIcon from "../assets/image.png";


<img class="patient" :src="imageIcon" />

第二种:

 import.meta.url 是一个 ESM 的原生功能,会暴露当前模块的 URL。将它与原生的 URL 构造器 组合使用,在一个 JavaScript 模块中,通过相对路径我们就能得到一个被完整解析的静态资源 URL。

const url = new URL('静态路径', import.meta.url).href

第一个参数即图片的路径,这里就是对应require中的值。

第二个参数是vite的一个全局变量,可以理解成直接写死了 import.meta.url

使用示例:

<img :src="index !== clickIndex ? downImg : upImg">

// 导入两张图片 
const downImg = new URL('../../assets/index/down.png', import.meta.url).href
const upImg = new URL('../../assets/index/up.png', import.meta.url).href

猜你喜欢

转载自blog.csdn.net/ONLYSRY/article/details/131112670
今日推荐