溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Vue中動(dòng)態(tài)引入圖片要require的原因是什么

發(fā)布時(shí)間:2022-11-01 09:16:03 來源:億速云 閱讀:141 作者:iii 欄目:開發(fā)技術(shù)

這篇“Vue中動(dòng)態(tài)引入圖片要require的原因是什么”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Vue中動(dòng)態(tài)引入圖片要require的原因是什么”文章吧。

1.什么是靜態(tài)資源

與靜態(tài)資源相對(duì)應(yīng)的還有一個(gè)動(dòng)態(tài)資源,先讓我們看看網(wǎng)上的各位大佬們?cè)趺唇忉尩摹?/p>

靜態(tài)資源:一般客戶端發(fā)送請(qǐng)求到web服務(wù)器,web服務(wù)器從內(nèi)存在取到相應(yīng)的文件,返回給客戶端,客戶端解析并渲染顯示出來。

動(dòng)態(tài)資源:一般客戶端請(qǐng)求的動(dòng)態(tài)資源,先將請(qǐng)求交于web容器,web容器連接數(shù)據(jù)庫(kù),數(shù)據(jù)庫(kù)處理數(shù)據(jù)之后,將內(nèi)容交給web服務(wù)器,web服務(wù)器返回給客戶端解析渲染處理。

站在一個(gè)vue項(xiàng)目的角度,我們可以簡(jiǎn)單的理解為:

靜態(tài)資源就是直接存放在項(xiàng)目中的資源,這些資源不需要我們發(fā)送專門的請(qǐng)求進(jìn)行獲取。比如assets目錄下面的圖片,視頻,音頻,字體文件,css樣式表等。

動(dòng)態(tài)資源就是需要發(fā)送請(qǐng)求獲取到的資源。比如我們刷淘寶的時(shí)候,不同的商品信息是發(fā)送的專門的請(qǐng)求獲取到的,就可以稱之為動(dòng)態(tài)資源。

2. 為什么動(dòng)態(tài)添加的src會(huì)被當(dāng)做的靜態(tài)的資源?

回答這個(gè)問題之前,我們需要了解一下,瀏覽器是怎么能運(yùn)行一個(gè)vue項(xiàng)目的。

我們知道瀏覽器打開一個(gè)網(wǎng)頁,實(shí)際上運(yùn)行的是html,css,js三種類型的文件。當(dāng)我們本地啟動(dòng)一個(gè)vue項(xiàng)目的時(shí)候,實(shí)際上是先將vue項(xiàng)目進(jìn)行打包,打包的過程就是將項(xiàng)目中的一個(gè)個(gè)vue文件轉(zhuǎn)編譯成html,css,js文件的過程,而后再在瀏覽器上運(yùn)行的。

那動(dòng)態(tài)添加的src如果我們沒有使用require引入,最終會(huì)打包成什么樣子呢,我?guī)Т蠹覍?shí)驗(yàn)一波。

// vue文件中動(dòng)態(tài)引入一張圖片
<template>
  <div class="home">
      <!-- 通過v-bind引入資源的方式就稱之為動(dòng)態(tài)添加 -->
    <img :src="'../assets/logo.png'" alt="logo">
  </div>
</template>

//最終編譯的結(jié)果(瀏覽器上運(yùn)行的結(jié)果)
//這張圖片是無法被正確打開的
<img src="../assets/logo.png" alt="logo">

我們可以看出,動(dòng)態(tài)添加的src最終會(huì)編譯成一個(gè)靜態(tài)的字符串地址。程序運(yùn)行的時(shí)候,會(huì)按照這個(gè)地址去項(xiàng)目目錄中引入資源。而 去項(xiàng)目目錄中引入資源的這種方式,就是將該資源當(dāng)成了靜態(tài)資源。所以這也就回答了我們的問題2。

看到這里估計(jì)就有小伙伴疑惑了,這個(gè)最終被編譯的地址有什么問題嗎?我項(xiàng)目中的圖片就是這個(gè)地址,為什么無法引入?別急,我們繼續(xù)往下看。

3. 沒有進(jìn)行編譯,是指的是什么沒有被編譯?

沒有進(jìn)行編譯。這半句話,就聽得很讓人懵逼了。按照問題2我們知道這個(gè)動(dòng)態(tài)引入的圖片最終是被編譯了,只是被編譯之后無法正確的引入圖片資源而已。所以這句話本來就是錯(cuò)的。針對(duì)于我們的標(biāo)準(zhǔn)答案,我在這里進(jìn)行改寫:

因?yàn)閯?dòng)態(tài)添加src被當(dāng)做靜態(tài)資源處理了,而被編譯過后的靜態(tài)路徑無法正確的引入資源,所以要加上require

那這里就誕生了一個(gè)新的疑問:被編譯過后的靜態(tài)路徑為什么無法正確的引入資源?

想得到這個(gè)問題的答案,我們得先從正常的引入一張圖片開始。在項(xiàng)目中我們靜態(tài)的引入一張圖片肯定是可以引入成功的,而引用圖片所在的vue文件肯定也是被編譯的,那靜態(tài)引入圖片最終會(huì)被編譯成什么樣呢,模擬一波:

// vue文件中靜態(tài)的引入一張圖片
<template>
  <div class="home">
      <!-- 直接引入圖片靜態(tài)地址, 不再使用v-bind -->
    <img src="../assets/logo.png" alt="logo">
  </div>
</template>

//最終編譯的結(jié)果
//這張圖片是可以被正確打開的
<img src="/img/logo.6c137b82.png" alt="logo">

根據(jù)上面的測(cè)試,我們發(fā)現(xiàn),使用靜態(tài)的地址去引入一張圖片,圖片的路徑和圖片的名稱已經(jīng)發(fā)生了改變,并且編譯后過后的靜態(tài)地址是可以成功的引入資源的。這是因?yàn)?,在默認(rèn)情況下,src目錄下面的所有文件都會(huì)被打包,src下面的圖片也會(huì)被打包在新的文件夾下并生成新的文件名。編譯過后的靜態(tài)地址引入的是打包過后的圖片地址,從而可以正確的引用資源

事實(shí)確實(shí)是這樣嗎?我們可以執(zhí)行打包命令(npm run build)進(jìn)行驗(yàn)證

Vue中動(dòng)態(tài)引入圖片要require的原因是什么

可以發(fā)現(xiàn),編譯過后的靜態(tài)地址確實(shí)是和dist下編譯后圖片地址是一致的,從而驗(yàn)證我們的想法。

到這里我們其實(shí)就可以解釋上面的問題了:動(dòng)態(tài)添加的src,被編譯過后的靜態(tài)路徑為什么無法正確的引入資源?

因?yàn)閯?dòng)態(tài)的添加的src編譯過后的地址,與圖片資源編譯過后的資源地址不一致, 導(dǎo)致無法正確的引入資源

  編譯過后的src地址:../assets/logo.png
  編譯過后的圖片資源地址:/img/logo.6c137b82.png

那要怎么解決上述的問題呢,答案就是:require

4. 加上require為什么能正確的引入資源,是因?yàn)榧由蟫equire就能編譯了?

針對(duì)這個(gè)問題,首先就要否定后半句,無論加不加require,vue文件中引入一張圖片都會(huì)被編譯。

接著我們?cè)賮砗煤昧私庖幌?,require。

4.1 require是什么: 是一個(gè)node方法,用于引入模塊,JSON或本地文件

4.2 調(diào)用require方法引入一張圖片之后發(fā)生了什么:

在回答這個(gè)問題之前,容我先對(duì)問題3中的內(nèi)容進(jìn)行一定的補(bǔ)充。其實(shí)如果真的有小伙伴跟著問題三中的操作進(jìn)行驗(yàn)證,估計(jì)就要開噴了:為什么我靜態(tài)引入的圖片最終編譯的地址和你的不一樣,是個(gè)base64,而且打包之后dist下面也沒有生成新的圖片。大概就是下面這樣的情況。

// vue文件中靜態(tài)的引入一張圖片
<template>
<div class="home">
    <!-- 直接引入圖片靜態(tài)地址, 不再使用v-bind -->
  <img src="../assets/logo.png" alt="logo">
</div>
</template>

//最終編譯的結(jié)果
//這張圖片是可以被正確打開的
<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAADICAYAAACtWK6eAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyNpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh7cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMDE0IDc5LjE1Njc5NywgMjAxNC8wOC8yMC0wOTo1MzowMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6OTk2QkI4RkE3NjE2MTFFNUE4NEU4RkIxNjQ5MTYyRDgiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6OTk2QkI4Rjk3NjE2MTFFNUE4NEU4RkIxNjQ5MTYyRDgiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIChNYWNpbnRvc2gpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6NjU2QTEyNzk3NjkyMTFFMzkxODk4RDkwQkY4Q0U0NzYiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6NjU2QTEyN0E3NjkyMTFFMzkxODk4RDkwQkY4Q0U0NzYiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz5WHowqAAAXNElEQVR42uxda4xd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" alt="logo">

先別急著噴,實(shí)際上造成這種差異的原因,是因?yàn)槲腋牧艘幌聎ebpack中的配置。接下來涉及少量webpack代碼,不了解webpack的小伙伴也沒關(guān)系,了解原理即可。

在上文中的我們提到,vue項(xiàng)目最終會(huì)被打包成一個(gè)dist目錄,那么是什么幫我們完成這個(gè)打包的呢,沒錯(cuò),就是webpack。在vue項(xiàng)目中的引入一張圖片的時(shí)候,細(xì)心的同學(xué)會(huì)發(fā)現(xiàn),有的時(shí)候,瀏覽器上顯示圖片地址是一個(gè)base64,有的時(shí)候,是一個(gè)被編譯過后的文件地址。也就是上述描述的差異。

之所以會(huì)造成這種差異,是webpack打包的時(shí)候,對(duì)圖片資源進(jìn)行了相關(guān)的配置。我們可以通過如下命令生成vue項(xiàng)目中的webpack配置文件,進(jìn)行驗(yàn)證:

npx vue-cli-service inspect --mode development >> webpack.config.development.js

Vue中動(dòng)態(tài)引入圖片要require的原因是什么

上圖就是vue中webpack默認(rèn)的圖片打包規(guī)則。設(shè)置 type: 'asset',默認(rèn)的,對(duì)于小于8k的圖片,會(huì)將圖片轉(zhuǎn)成base64 直接插入圖片,不會(huì)再在dist目錄生成新圖片。對(duì)于大于8k的圖片,會(huì)打包進(jìn)dist目錄,之后將新圖片地址返回給src。

而我在上述測(cè)試中使用的圖片,是vue-cli自帶的一張logo圖片,大小是6.69k。按照默認(rèn)的打包規(guī)則,是會(huì)轉(zhuǎn)成base64,嵌入圖片中的。所以為了講述方便,我在vue.config.js中修改了其默認(rèn)的配置,配置如下:

module.exports = {
    // 使用configureWebpack對(duì)象,下面可以直接按照webpack中的寫法進(jìn)行編寫
    // 編寫的內(nèi)容,最終會(huì)被webpack-merge插件合并到webpack.config.js主配置文件中
  configureWebpack: { 
    module: {
      rules: [
        {
          test: /\.(png|jpe?g|gif|webp|avif)(\?.*)?$/,
          type: 'asset',
          parser: {
            dataUrlCondition: {
             // 這里我將默認(rèn)的大小限制改成6k。
              // 當(dāng)圖片小于6k時(shí)候,使用base64引入圖片;大于6k時(shí),打包到dist目錄下再進(jìn)行引入
              maxSize: 1024 * 6
            }
          }
        }
      ]
    }
  }
}

那上面說了這么多,和require有啥關(guān)系,自然是有滴。

我們現(xiàn)在知道vue最終是通過webpack打包,并且會(huì)在webpack配置文件中編寫一系列打包規(guī)則。而webpack中的打包規(guī)則,針對(duì)的其實(shí)是一個(gè)一個(gè)模塊,換而言之webpack只會(huì)對(duì)模塊進(jìn)行打包。那webpack怎么將圖片當(dāng)成一個(gè)模塊呢,這就要用到我們的正主require。

當(dāng)我們使用require方法引入一張圖片的時(shí)候,webpack會(huì)將這張圖片當(dāng)成一個(gè)模塊,并根據(jù)配置文件中的規(guī)則進(jìn)行打包。我們可以將require當(dāng)成一個(gè)橋梁,使用了require方法引入的資源,該資源就會(huì)當(dāng)成模塊并根據(jù)配置文件進(jìn)行打包,并返回最終的打包結(jié)果。

回到問題4.2:調(diào)用require方法引入一張圖片之后發(fā)生了什么

1.如果這張圖片小于項(xiàng)目中設(shè)置的資源限制大小,則會(huì)返回圖片的base64插入到require方法的調(diào)用處

2.如果這張圖片大于項(xiàng)目中設(shè)置的資源限制大小,則會(huì)將這個(gè)圖片編譯成一個(gè)新的圖片資源。require方法返回新的圖片資源路徑及文件名

回到問題4:為什么加上require能正確的引入資源

因?yàn)橥ㄟ^require方法拿到的文件地址,是資源文件編譯過后的文件地址(dist下生成的文件或base64文件),因此可以找對(duì)應(yīng)的文件,從而成功引入資源。

答案就是這么簡(jiǎn)單,來驗(yàn)證一波

// vue文件中使用require動(dòng)態(tài)的引入一張圖片
<template>
  <div class="home">
      <!-- 使用require動(dòng)態(tài)引入圖片 -->
      <img :src="require('../assets/logo.png')" alt="logo">
  </div>
</template>

//最終編譯的結(jié)果
//這張圖片是可以被正確打開的
<img src="/img/logo.6c137b82.png" alt="logo">

Vue中動(dòng)態(tài)引入圖片要require的原因是什么

有問題嗎,沒有問題。到這里,不妨再對(duì)我們的標(biāo)準(zhǔn)答案進(jìn)行一次優(yōu)化:

因?yàn)閯?dòng)態(tài)添加的src,編譯過后的文件地址和被編譯過后的資源文件地址不一致,從而無法正確引入資源。而使用require,返回的就是資源文件被編譯后的文件地址,從而可以正確的引入資源

看到這,估計(jì)還是有一些小伙伴有一些疑問,我再擴(kuò)展一波:

5. 問題3中,靜態(tài)的引入一張圖片,沒有使用require,為什么返回的依然是編譯過后的文件地址?

答:在webpack編譯的vue文件的時(shí)候,遇見src等屬性會(huì)默認(rèn)的使用require引入資源路徑。引用vue-cli官方的一段原話

當(dāng)你在 JavaScript、CSS 或 *.vue 文件中使用相對(duì)路徑 (必須以 . 開頭) 引用一個(gè)靜態(tài)資源時(shí),該資源將會(huì)被包含進(jìn)入 webpack 的依賴圖中。在其編譯過程中,所有諸如 <img src="...">background: url(...) 和 CSS @import 的資源 URL 都會(huì)被解析為一個(gè)模塊依賴。

例如,url(./image.png) 會(huì)被翻譯為 require('./image.png'),而:

<img src="./image.png">

將會(huì)被編譯到:

h('img', { attrs: { src: require('./image.png') }})

6. 按照問題6中所說,那么動(dòng)態(tài)添加src的時(shí)候也會(huì)使用require引入,為什么src編譯過后的地址,與圖片資源編譯過后的資源地址不一致

答:因?yàn)閯?dòng)態(tài)引入一張圖片的時(shí)候,src后面的屬性值,實(shí)際上是一個(gè)變量。webpack會(huì)根據(jù)v-bind指令去解析src后面的屬性值。并不會(huì)通過reuqire引入資源路徑。這也是為什么需要手動(dòng)的添加require。

7.據(jù)說public下面的文件不會(huì)被編譯,那我們使用靜態(tài)路徑去引入資源的時(shí)候,也會(huì)默認(rèn)的使用require引入嗎?

官方的原文是這樣子的:

任何放置在 public 文件夾的靜態(tài)資源都會(huì)被簡(jiǎn)單的復(fù)制,而不經(jīng)過 webpack。你需要通過絕對(duì)路徑來引用它們。

答:不會(huì),使用require引入資源的前提的該資源是webpack解析的模塊,而public下的文件壓根就不會(huì)走編譯,也就不會(huì)使用到require。

8.為什么使用public下的資源一定要絕對(duì)路徑

答:因?yàn)殡m然public文件不會(huì)被編譯,但是src下的文件都會(huì)被編譯。由于引入的是public下的資源,不會(huì)走require,會(huì)直接返回代碼中的定義的文件地址,該地址無法在編譯后的文件目錄(dist目錄)下找到對(duì)應(yīng)的文件,會(huì)導(dǎo)致引入資源失敗。

9.上文件中提到的webpack,為什么引入資源的時(shí)候要有base64和打包到dist目錄下兩種的方式,全部打包到的dist目錄下,他不香嗎?

答:為了減少http請(qǐng)求。頁面中通過路徑引入的圖片,實(shí)際上都會(huì)向服務(wù)器發(fā)送一個(gè)請(qǐng)求拿到這張圖片。對(duì)于資源較小的文件,設(shè)置成base64,既可以減少請(qǐng)求,也不會(huì)影響到頁面的加載性能。

以上就是關(guān)于“Vue中動(dòng)態(tài)引入圖片要require的原因是什么”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI