Vue3+Vite中不支持require的方式引入本地图片的解决方案
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
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
vue-router中的hash和history两种模式的区别
大家都知道vue-router有两种模式,hash模式和history模式,这里来谈谈vue-router中的hash和history两种模式的区别。感兴趣的朋友一起看看吧2018-07-07Vue3动态路由(响应式带参数的路由)变更页面不刷新的问题解决办法
问题来源是因为我的开源项目Maple-Boot项目的网站前端,因为项目主打的内容发布展示,所以其中的内容列表页会根据不同的菜单进行渲染不同的路由,本文降介绍Vue3动态路由变更页面不刷新的问题解决办法,需要的朋友可以参考下2024-07-07
最新评论