ホームページ >ウェブフロントエンド >Vue.js >vue3+vite: src に画像を動的にインポートするために require を使用するときのエラーを解決する方法
vue3 TypeScript 開発を使用している場合、イメージをインポートするために require が表示されますエラーが報告され、require が定義されておらず、vue2 を使用する場合のように imgUrl: require(’…/assets/test.png’) をインポートできません。これは、typescript が require
をサポートしていないため、インポートが使用されます解決方法は次のとおりです: await import(’@/assets/img/22.png’);
<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 vite:src require を使用して絶対パスを導入し、エラーを報告します最新のプロジェクトは vue3 vite です。require を使用してイメージ パスを参照すると、「require が定義されていません」というエラーが報告されます。非常に恥ずかしいです。typescript は require をサポートしていないため、imgUrl を直接使用しました: require(’…/assets /test.png’) はインポート時にエラーを報告します。インポートするには import を使用する必要があります。解決策を記録します: 最初のメソッド: await import(’@/assets/img/22.png’);
<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>
<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+vite: src に画像を動的にインポートするために require を使用するときのエラーを解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。