webapck構建文件命名hash chunkhash contenthash區別

hash是通過既定的數據摘要算法(目前使用最廣泛的是md5)計算出來的hash值。

webpack內置的hash相關的配置有兩個:hash和chunkhash。

名稱 webapck 1 webapck 2及以上
hash The hash of compilation The hash of module identifier
chunkhash The hash of the chunk The hash of the chunk content

webpack的compilation對象代表某個版本的資源對應的編譯進程。當使用webpack的development中間件時,每次檢測到項目文件有改動就會創建一個新的compilation,進而能夠針對改動產生全新的編譯文件。compilation對象包含當前模塊資源、待編譯文件、有改動的文件和監聽依賴的所有信息。

注:與compilation對應的有個compiler對象,通過對比,可以幫助大家對compilation有更深入的理解。compiler對象代表的是配置完備的Webpack環境。 compiler對象只在Webpack啟動時構建一次,由Webpack組合所有的配置項構建生成。compiler對象代表的是不變的webpack環境,是webpack本身,而compilation對象針對的是隨時可變的項目文件,只要文件有改動,compilation就會被重新創建。

  • hash

對于hash的理解,我認為webpack 1中的The hash of compilation定義更準確,可以理解成是項目總體文件的hash值。所以若打包文件輸出時以hash命名,項目中任何一個文件修改構建后都會生成新的hash,會影響所有資源的緩存。比如webpack配置如下:

output: {
  filename: '[name].[hash:8].js'
}
  • chunkhash

chunk在webpack中的含義可以理解成多個模塊合并成的一個"新模塊",依據其自身的代碼內容根據一定的摘要算法所得的hash值。也就是特定模塊獨有的hash值。webpack配置更改如下:

output: {
  filename: '[name].[chunkhash:8].js'
}

此時編譯后輸出的文件名中的hash值將不再一樣。

  • contenthash

contenthash并不是webpack的另外一中hash,而是由ExtractTextPlugin插件(主要作用: 將css代碼從打包后的js代碼中分離出來)提供的,代表被導出的css部分代碼內容計算后的的hash值

1. 在webpack構建過程中,我們可以狹隘的認為他只認js文件,其他文件都需要借助js文件構建,比如css資源必須都在js中引入。例如在main.js文件中引入main.css文件:

import 'main.css';

2. webpack默認將構建后的css代碼合并到引用它的js文件中。那么css是怎么引入到頁面中的呢?
----其實就是js在運行的時候動態創建style標簽,然后append進head中的。所以在本地開發中若是沒有開啟ExtractTextPlugin的話,那么css代碼都是內聯在html中的。

3. 盡然chunkhash已經能以一個文件為單位去生成一個特定的chunkhash了那,那么為什么還要用contenthash呢?
大家考慮怎么一個場景:
----假設有主模塊main.js, 同步模塊sync.js,其中mian.js中引入了main.css, 將這三個模塊按下面代碼的配置進行構建打包到“同一個文件”(此時配置了ExtractTextPlugin插件,css代碼會單獨抽離到一個文件,若不添加ExtractTextPlugin會被打包到一個js文件)

{
  test: /\.css$/,
  use: ExtractTextPlugin.extract({
    filename: './dist/[name].[chunkhash:8].css',
    use: [
      'css-loader',
      'postcss-loader',
    ],
  }),
}

構建后會輸出main.8a132fcd.jsmain.8a132fcd.css兩個文件,二者的chunkname和hash會是一樣的;

① 若后續我們修改了main.js或是sync.js里面的代碼,重新構建后,會生成新的chunkhash,那么構建后的js文件和css文件的hash都會改變。
② 若是我們值修改了main.css代碼的話,重新構建后,會發現chunkhash并未改變,這是為什么?
-----這是因為導入ExtractTextPlugin后會將css代碼獨立導出,它的修改不會引起主js文件chunkhash的改變,sync.js、mian.js、main.css三個文件本屬于同一個chunk,被導出的css雖然不會參與chunkhash的計算,但是也不會做為一個獨立的chunk計算,所以name和hash還是取主js文件的。

這樣就會有一個問題,要是css改變了的話,重新構建后的css文件名并沒有改變會導致用戶瀏覽器還是會拉取緩存中的資源,所以最好還是配置成如下的contenthash

{
  test: /\.css$/,
  use: ExtractTextPlugin.extract({
    filename: './dist/[name].[contenthash:8].css',
    use: [
      'css-loader',
      'postcss-loader',
    ],
  }),
}

這樣改后修改main.js或者sync.js,css文件的hash不會變,若單獨修改css,那么主js文件的hash也不會改變

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,572評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,071評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,409評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,569評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,360評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,895評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,979評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,123評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,643評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,559評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,742評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,250評論 5 356
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,981評論 3 346
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,363評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,622評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,354評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,707評論 2 370

推薦閱讀更多精彩內容