vue3 + vite 动态的导入多张图片
vue3 如果使用的是typescript开发,就会出现require引入图片报错,require is not defined 不能像使用vue2 这样imgUrl: require(’…/assets/test.png’) 导入,是因为typescript不支持require
所以用import导入,下面介绍如何解决: 使用await import(’@/assets/img/22.png’);
demo1.vue
<template>
<img :src="imgUrl" alt="">
</template>
<script>
import {ref, onMounted} from "vue";
export default {
name: "imgPage",
setup(){
onMounted(()=>{
handleImgSrc();
})
const imgUrl = ref('');
const handleImgSrc = async()=>{
let m = await import('@/assets/img/22.png');
imgUrl.value = m.default;
};
return{
imgUrl
}
}
}
</script>
demo2.vue 循环利用返回值请求本地图片
<template>
<img v-for="item in imgList" :src="getAssetsImages(item.url)" alt="">
</template>
<script>
import {ref, reactive, onMounted} from "vue";
export default {
name: "imgPage",
setup(){
const imgList = reactive([
{url: 'a.png'},{url: 'b.png'},{url: 'c.png'}
])
const getAssetsImages =(name)=> {
return new URL(`/src/assets/pic/${name}`, import.meta.url).href; //本地文件路径
}
return{
imgList ,
getAssetsImages
}
}
}
</script>
记录一下使用vue3遇到的问题,或许还有别的办法解决图片引入问题,还请各位指教~
在Vue3中使用TypeScript开发时,由于不支持`require`语法,导致无法像Vue2那样导入图片。本文介绍了两种解决方案:1) 使用`import()`动态导入图片,并在`onMounted`钩子中处理;2) 在循环中利用`new URL`构造函数获取本地图片路径。这两种方法解决了Vue3中typescript环境下图片导入的问题。

8487

被折叠的 条评论
为什么被折叠?



