vue3+vite :src 用require 动态导入图片报错和解决方法

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遇到的问题,或许还有别的办法解决图片引入问题,还请各位指教~

猜你喜欢

转载自blog.csdn.net/qq_37656005/article/details/119893651
今日推荐