欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3+vite2實(shí)現(xiàn)動態(tài)綁定圖片的優(yōu)雅解決方案

 更新時間:2023年08月24日 08:43:55   作者:前端cry  
這篇文章主要為大家詳細(xì)介紹了vue3+vite2實(shí)現(xiàn)動態(tài)綁定圖片的優(yōu)雅解決方案,文中的示例代碼簡潔易懂,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

背景

在vue3+vite2項(xiàng)目中,我們有時候想要動態(tài)綁定資源,比如像下面的代碼這樣:

<template>
    <div>
	    <!-- 動態(tài)綁定圖片資源 -->
        <img :src="img_src">
    </div>
</template>
<script setup>
import { ref } from 'vue';
// 靜態(tài)圖片資源
const img_src = ref('./1.jpg');
</script>

實(shí)際效果是這樣:

原因分析

我們注意到,控制臺的報(bào)錯信息GET http://127.0.0.1:5173/1.jpg 404 (Not Found)

  • GET:表示向服務(wù)器請求資源的方式。
  • http://127.0.0.1:5173:表示主機(jī)為項(xiàng)目開啟的服務(wù)器地址以及端口號
  • http://127.0.0.1:5173/1.jpg:表示存放在服務(wù)器中的圖片資源地址。
  • 404 (Not Found):狀態(tài)碼,404表示找不到資源。

問題就出在http://127.0.0.1:5173/1.jpg 這里,項(xiàng)目文件的路徑是src/App.vue ,圖片的路徑是src/1.jpg ,因此,圖片在服務(wù)器上的存放路徑實(shí)際應(yīng)該是http://127.0.0.1:5173/src/1.jpg ,我們直接在瀏覽器中訪問這個地址。

可以看到,成功獲取了圖片資源。

由于vite打包的機(jī)制,造成了路徑錯誤的問題(類似于vue2 + vue-cli項(xiàng)目的動態(tài)綁定圖片問題)。

解決

目前網(wǎng)上的解決方案有很多,這里列出其中一種受眾的,以及筆者在此基礎(chǔ)上進(jìn)一步加強(qiáng)的解決方案。

普遍的解決方案

話不多說,直接列出代碼:

<template>
    <div>
	    <!-- 動態(tài)綁定圖片資源 -->
        <img :src="img_src">
    </div>
</template>
<script setup>
import { ref } from 'vue';
// 靜態(tài)圖片資源
const img_src = ref('./1.jpg');
// 主要代碼,利用 new URL().href 進(jìn)行相對路徑的拼接
function getAssetImage(imgSrc) {
  return new URL(imgSrc, import.meta.url).href;
}
// 當(dāng)然你也可以這樣簡寫,這里用到es6箭頭函數(shù)
// const getAssetImage = imgSrc => new URL(imgSrc, import.meta.url).href;
</script>

這段代碼的重點(diǎn)是new URL().href 和 es6的 import.meta.url 。

  • new URL(url, baseUrl).href:路徑拼接。比如url是./1.jpg,baseUrl是http://127.0.0.1:5173/src/App.vue ,那么拼接出來就是http://127.0.0.1:5173/src/1.jpg
  • import.meta.url:獲取當(dāng)前模塊的路徑,比如在src/App.vue中,就是http://127.0.0.1:5173/src/App.vue。

所以最后的new URL().href 就是真正的圖片資源地址,自己打印一下new URL(url, baseUrl) 和import.meta.url 就容易明白了。

這里給大伙兒畫張圖,便于理解。

優(yōu)雅的解決方案

上面的方案可行,但不夠優(yōu)雅。試想,如果有很多文件都需要動態(tài)綁定靜態(tài)圖片資源,那豈不是每個.vue文件都要封裝一次getAssetImage() 函數(shù)?所以下面介紹一種優(yōu)雅的封裝方案。

封裝的主要問題是如何自動獲取.vue文件的import.meta.url ,就可以不必每次調(diào)用都攜帶import.meta.url。

核心思路是通過拋出錯誤獲取函數(shù)調(diào)用棧,從而獲得函數(shù)調(diào)用者文件(或者說模塊)的路徑,再通過正則表達(dá)式提取出路徑信息,把import.meta.url替換掉,就能實(shí)現(xiàn),只傳圖片相對路徑這一個參數(shù),得到圖片的完整路徑的效果。

直接上代碼:

JavaScript版本

// src/utils/common.js
export default {
    getAssetImage(imgSrc, baseUrl) {
        // console.log('baseUrl', baseUrl);
        // console.log('new URL(imgSrc, baseUrl).href', new URL(imgSrc, baseUrl).href);
        // console.log('import.meta.url', import.meta.url);
        // console.log('new URL(imgSrc, import.meta.url).href', new URL(imgSrc, import.meta.url).href);
        // 正則匹配函數(shù)調(diào)用者文件的路徑
        const regExp1 = /at Proxy.getAssetImage \((.+)\)/g;
        // 正則命中目標(biāo)
        let target;
        try {
            // 拋出錯誤,獲取函數(shù)調(diào)用棧信息
            throw new Error();
        } catch (err) {
            // 匹配函數(shù)調(diào)用者文件的路徑
            target = regExp1.exec(err?.stack);
            // console.log('err.stack', err?.stack);
            // console.log(target?.[1]);
        }
        if (target?.[1]) {
            // 用戶沒有傳入第二個參數(shù),就使用自動獲取的路徑
            baseUrl = baseUrl || target?.[1];
        }
        if (!baseUrl) {
            // 用戶沒有傳入第二個參數(shù),且獲取函數(shù)調(diào)用者文件的路徑失敗
            throw new Error('請傳入第二個參數(shù) import.meta.url');
        }
        // 返回處理后的資源路徑
        return new URL(imgSrc, baseUrl).href;
    }
}

TypeScript版本

// src/utils/common.ts
export default {
    getAssetImage(imgSrc: string, baseUrl: string) {
        // console.log('baseUrl', baseUrl);
        // console.log('new URL(imgSrc, baseUrl).href', new URL(imgSrc, baseUrl).href);
        // console.log('import.meta.url', import.meta.url);
        // console.log('new URL(imgSrc, import.meta.url).href', new URL(imgSrc, import.meta.url).href);
        // 正則匹配函數(shù)調(diào)用者文件的路徑
        const regExp1 = /at Proxy.getAssetImage \((.+)\)/g;
        // 正則命中目標(biāo)
        let target: RegExpExecArray | null;
        try {
            // 拋出錯誤,獲取函數(shù)調(diào)用棧信息
            throw new Error();
        } catch (err) {
            // 匹配函數(shù)調(diào)用者文件的路徑
            target = regExp1.exec(err?.stack);
            // console.log('err.stack', err?.stack);
            // console.log(target?.[1]);
        }
        if (target?.[1]) {
            // 用戶沒有傳入第二個參數(shù),就使用自動獲取的路徑
            baseUrl = baseUrl || target?.[1];
        }
        if (!baseUrl) {
            // 用戶沒有傳入第二個參數(shù),且獲取函數(shù)調(diào)用者文件的路徑失敗
            throw new Error('請傳入第二個參數(shù) import.meta.url');
        }
        // 返回處理后的資源路徑
        return new URL(imgSrc, baseUrl).href;
    }
}

在.vue文件中使用

// src/App.vue
<template>
    <div>
        <!-- 測試 -->
        <img :src="getAssetImage(img_src)">
        <!-- 可以試試在嵌套組件中使用^_^ -->
    </div>
</template>
<script lang="ts" setup>
import { ref } from 'vue';
import common from '@/utils/common.ts';
const img_src = ref('./1.jpg');
// const getAssetImage = img_src => common.getAssetImage(img_src, import.meta.url);
// 可以省略第二個參數(shù)import.meta.url,函數(shù)內(nèi)部會自動獲取函數(shù)的調(diào)用路徑。
const getAssetImage = img_src => common.getAssetImage(img_src);
// 常規(guī)寫法
// function getAssetImage(img_src) {
//   return common.getAssetImage(img_src);
// }
</script>

到此這篇關(guān)于vue3+vite2實(shí)現(xiàn)動態(tài)綁定圖片的優(yōu)雅解決方案的文章就介紹到這了,更多相關(guān)vue3 vite2動態(tài)綁定圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue響應(yīng)式更新機(jī)制及不使用框架實(shí)現(xiàn)簡單的數(shù)據(jù)雙向綁定問題

    vue響應(yīng)式更新機(jī)制及不使用框架實(shí)現(xiàn)簡單的數(shù)據(jù)雙向綁定問題

    vue是一款具有響應(yīng)式更新機(jī)制的框架,既可以實(shí)現(xiàn)單向數(shù)據(jù)流也可以實(shí)現(xiàn)數(shù)據(jù)的雙向綁定。這篇文章主要介紹了vue響應(yīng)式更新機(jī)制及不使用框架實(shí)現(xiàn)簡單的數(shù)據(jù)雙向綁定問題,需要的朋友可以參考下
    2019-06-06
  • vue第三方庫中存在擴(kuò)展運(yùn)算符報(bào)錯問題的解決方案

    vue第三方庫中存在擴(kuò)展運(yùn)算符報(bào)錯問題的解決方案

    這篇文章主要介紹了vue第三方庫中存在擴(kuò)展運(yùn)算符報(bào)錯問題,本文給大家分享解決方案,通過結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • Vue實(shí)現(xiàn)在線預(yù)覽pdf文件功能(利用pdf.js/iframe/embed)

    Vue實(shí)現(xiàn)在線預(yù)覽pdf文件功能(利用pdf.js/iframe/embed)

    項(xiàng)目要求需要預(yù)覽pdf文件,網(wǎng)上找了很久,發(fā)現(xiàn)pdf.js的效果,這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)在線預(yù)覽pdf文件功能,主要利用pdf.js/iframe/embed來實(shí)現(xiàn)的,需要的朋友可以參考下
    2021-06-06
  • 在vue中使用?jquery?的兩種方法小結(jié)

    在vue中使用?jquery?的兩種方法小結(jié)

    這篇文章主要介紹了在vue中使用?jquery?的兩種方法小結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Avue自定義formslot調(diào)用rules自定義規(guī)則方式

    Avue自定義formslot調(diào)用rules自定義規(guī)則方式

    在Avue框架中,使用formslot自定義表格列時可能會遇到無法調(diào)用Avue的自定義校驗(yàn)規(guī)則的問題,這通常發(fā)生在嘗試通過formslot自定義設(shè)置列的場景中,解決這一問題的一個有效方法是將自定義列與Avue的校驗(yàn)規(guī)則通過特定方式連接起來
    2024-10-10
  • vue 按鈕 權(quán)限控制介紹

    vue 按鈕 權(quán)限控制介紹

    這篇文章主要介紹了vue 按鈕 權(quán)限控制,在日常項(xiàng)目中,會碰到需要根據(jù)后臺接口返回的數(shù)據(jù),來判斷當(dāng)前用戶的操作權(quán)限,必須當(dāng)有刪除權(quán)限時,就顯示刪除按鈕,下面我們就來了解一下具體的解決方法,需要的朋友也可以參考一下
    2021-12-12
  • vue實(shí)現(xiàn)用戶長時間不操作自動退出登錄功能的實(shí)現(xiàn)代碼

    vue實(shí)現(xiàn)用戶長時間不操作自動退出登錄功能的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue實(shí)現(xiàn)用戶長時間不操作自動退出登錄功能的實(shí)現(xiàn)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • VUE3基于vite封裝條形碼和二維碼組件的詳細(xì)過程

    VUE3基于vite封裝條形碼和二維碼組件的詳細(xì)過程

    基礎(chǔ)組件開發(fā)是項(xiàng)目業(yè)務(wù)開發(fā)的基石, 本文主要介紹了通過vue3的vite腳手架快速搭建項(xiàng)目, 開發(fā)條形碼和二維碼組件的過程,感興趣的朋友跟隨小編一起看看吧
    2023-08-08
  • VUE異步更新DOM - 用$nextTick解決DOM視圖的問題

    VUE異步更新DOM - 用$nextTick解決DOM視圖的問題

    這篇文章主要介紹了VUE異步更新DOM - 用$nextTick解決DOM視圖的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue2實(shí)現(xiàn)組件延遲加載的示例代碼

    Vue2實(shí)現(xiàn)組件延遲加載的示例代碼

    當(dāng)一個頁面需要加載較多個組件時,并且組件自身又比較復(fù)雜,如果一次性加載,可能等待時間較長,體驗(yàn)不好,這個時候就需要延遲加載了,本文為大家介紹了Vue2實(shí)現(xiàn)組件延遲加載的示例代碼,需要的可以參考下
    2024-01-01

最新評論