vue3如何加載本地圖片等靜態(tài)資源淺析
背景
在我們用 vue2 + webpack 的時候,加載圖片資源是這樣用的:
<img :src="require('@/assets/test.png')" />
這樣打包后就會觸發(fā) file-loader
打包圖片資源,在 dist 文件夾中就可以看到這個圖片(如果圖片較小會打包進(jìn)代碼中變?yōu)?base64 引入)。
但是在 vue3 + vite 中,使用這種方式是不行的,vite 中沒有 require 會報(bào)錯。
解決方案 官方文檔 中提到了兩種方案,今天我來驗(yàn)證一下。
將資源引入為 URL
import chatHealth from '@/assets/chat-health.png' <img :src="chatHealth" alt="" />
可以看到,由于這張圖片較小被打包成為了 base64,所以 dist 文件夾沒有輸出這個圖片。
接下來我拿一張大圖試驗(yàn)一下,發(fā)現(xiàn)確實(shí)打包出來了。
所以這種方法親測有效。
new URL(url, import.meta.url)
第二種方法是:
<img :src="getImgUrl('chat-health.png')" alt="" /> const getImgUrl = (name: string) => { return new URL('../../../../../assets/' + name, import.meta.url).href }
使用這種方法,在本地運(yùn)行的時候可以加載出來圖片。
但是發(fā)到真實(shí)環(huán)境(測試/線上),發(fā)現(xiàn)找不到文件了,我看了下目錄指向的是:
但這個路徑并不對,然后我再看打包后的文件
發(fā)現(xiàn)打包后的文件并沒有這個圖片,這里我有點(diǎn)不太懂問題出在哪里?
感覺好像就是 vite 沒有去加載這個圖片,所以打包文件看不到,并不是因?yàn)閳D片小,我換了一個大圖依舊 dist 沒有,不知道是不是我哪里操作不對。
結(jié)尾
對比這兩種方案,我只試驗(yàn)成功了第一種,第二種如果是我哪里操作不對的歡迎指正
到此這篇關(guān)于vue3如何加載本地圖片等靜態(tài)資源的文章就介紹到這了,更多相關(guān)vue3加載本地圖片靜態(tài)資源內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Nuxt引用cookie-universal-nuxt在服務(wù)端請求cookie方式
這篇文章主要介紹了Nuxt引用cookie-universal-nuxt在服務(wù)端請求cookie方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10vue中v-text / v-html使用實(shí)例代碼詳解
這篇文章主要介紹了vue中v-text / v-html使用實(shí)例代碼詳解,非常不錯,代碼簡單易懂,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04解決vue-router 二級導(dǎo)航默認(rèn)選中某一選項(xiàng)的問題
今天小編就為大家分享一篇解決vue-router 二級導(dǎo)航默認(rèn)選中某一選項(xiàng)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11VUE2 前端實(shí)現(xiàn) 靜態(tài)二級省市聯(lián)動選擇select的示例
下面小編就為大家分享一篇VUE2 前端實(shí)現(xiàn) 靜態(tài)二級省市聯(lián)動選擇select的示例。具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02vue在mounted拿不到props中傳遞的數(shù)據(jù)問題
這篇文章主要介紹了vue在mounted拿不到props中傳遞的數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03你不知道的Vue技巧之--開發(fā)一個可以通過方法調(diào)用的組件(推薦)
這篇文章主要介紹了你不知道的Vue技巧之--開發(fā)一個可以通過方法調(diào)用的組件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04