vue2.0 資源文件assets和static的區(qū)別詳解
資源文件處理
在我們的項目結(jié)構(gòu)里,有兩個資源文件的路徑,分別是:src/assets 和 static/。那這兩個到底有什么區(qū)別呢?
Webpacked 資源
為了回答這個問題,我們首先需要理解webpack是怎樣處理靜態(tài)資源的。在*.vue組件中,所有的templates和css都會被vue-html-loader 和 css-loader解析,尋找資源的URL。
舉個例子,在 <img src="./logo.png"> 和 background: url(./logo.png), “./logo.png”中,都是相對資源路徑,都會被Webpack解析成模塊依賴 。
由于logo.png不是JavaScript,當被看成一個模塊依賴的時候,我們需要使用url-loader 和 file-loader進行處理。 該模板已經(jīng)配置好了這些loaders,所以你能夠使用相對/模塊路徑時不需要擔(dān)心部署的問題。由于這些資源可能在構(gòu)建的時候被內(nèi)聯(lián)/復(fù)制/重命名, 所以它們從本質(zhì)上來說是你源碼的一部分。這就是為什么我們建議將交由webpack處理的靜態(tài)資源和其它源文件一樣放在/src路徑下面。實際上,你甚至不需要把它們?nèi)挤旁?src/assets路徑下:你可以基于模塊/組件的使用來組織文件結(jié)構(gòu)。例如,你可以把每個組件和屬于它的靜態(tài)資源放在它自己的目錄下。
資源處理規(guī)則
相對URL, e.g. ./assets/logo.png 將會被解釋成一個模塊依賴。它們會被一個基于你的Webpack輸出配置自動生成的URL替代。沒有前綴的URL, e.g. assets/logo.png 將會被看成相對URL,并且轉(zhuǎn)換成./assets/logo.png
前綴帶~的URL 會被當成模塊請求, 類似于require(‘some-module/image.png'). 如果你想要利用Webpack的模塊處理配置,就可以使用這個前綴。例如,如果你有一個對于assets的路徑解析,你需要使用 <img src="~assets/logo.png"> 來確保解析是對應(yīng)上的。相對根目錄的URL, e.g. /assets/logo.png 是不會被處理的
在 Javascript中獲取資源路徑
為了能讓W(xué)ebpack返回正確的資源路徑,你需要使用require(‘./relative/path/to/file.jpg'),由file-loader進行解析,然后返回處理過的URL。例如:
computed: { background () { return require('./bgs/' + this.id + '.jpg') } }
注意上面的例子,在最終的構(gòu)建時將會包含./bgs/路徑下的所有圖片 這是因為Webpack不能猜出來在運行時會用到其中的哪個,所以會包含所有的。
“真實的” 靜態(tài)資源
作為對比,在static/下的文件都不會被Webpack處理:它們使用相同的文件名,直接拷貝到最終的路徑。你必須使用絕對路徑來引用這些文件,取決于在config.js里面加入的build.assetsPublicPath 和 build.assetsSubDirectory。
舉個例子,下面的默認值是:
// config/index.js module.exports = { // ... build: { assetsPublicPath: '/', assetsSubDirectory: 'static' } }
所有放在 static/目錄下的文件都應(yīng)該是使用絕對URL/static/[filename]引用的。如果你將assetSubDirectory的值改成assets, 那么這些URL就會被變成 /assets/[filename]
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vscode搭建vue環(huán)境完整圖文教程(適合新手小白)
Vue框架的優(yōu)秀設(shè)計和強大的生態(tài)系統(tǒng)成為了越來越多開發(fā)者選擇Vue的原因,在實際項目過程中一個高效的開發(fā)環(huán)境能夠大大提高開發(fā)效率,這篇文章主要給大家介紹了關(guān)于vscode搭建vue環(huán)境的相關(guān)資料,需要的朋友可以參考下2023-10-10詳解vuex 中的 state 在組件中如何監(jiān)聽
本篇文章主要介紹了詳解vuex 中的 state 在組件中如何監(jiān)聽,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05關(guān)于vue跳轉(zhuǎn)后頁面置頂?shù)膯栴}
這篇文章主要介紹了關(guān)于vue跳轉(zhuǎn)后頁面置頂?shù)膯栴},具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05vue異步axios獲取的數(shù)據(jù)渲染到頁面的方法
今天小編就為大家分享一篇vue異步axios獲取的數(shù)據(jù)渲染到頁面的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08Vue監(jiān)聽滾動實現(xiàn)錨點定位(雙向)示例
今天小編大家分享一篇Vue監(jiān)聽滾動實現(xiàn)錨點定位(雙向)示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11