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

簡(jiǎn)單談?wù)凜ommonsChunkPlugin抽取公共模塊

 更新時(shí)間:2017年12月31日 10:04:21   作者:wonyun  
下面小編就為大家分享一篇簡(jiǎn)單談?wù)凜ommonsChunkPlugin抽取公共模塊,具有很的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

引言

webpack插件CommonsChunkPlugin的主要作用是抽取webpack項(xiàng)目入口chunk的公共部分,具體的用法就不做過(guò)多介紹,不太了解可以參考webpack官網(wǎng)介紹;

該插件是webpack項(xiàng)目常用的一個(gè)優(yōu)化功能,幾乎在每個(gè)webpack項(xiàng)目中都會(huì)用到。使用該插件帶來(lái)的好處:

提升webpack打包速度和項(xiàng)目體積:將webpack入口的chunk文件中所有公共的代碼提取出來(lái),減少代碼體積;同時(shí)提升webpack打包速度。

利用緩存機(jī)制:依賴的公共模塊文件一般很少更改或者不會(huì)更改,這樣獨(dú)立模塊文件提取出可以長(zhǎng)期緩存。

但是在項(xiàng)目中,若插件打開方式不正確的話,上面的第二點(diǎn)其實(shí)是無(wú)法實(shí)現(xiàn),因?yàn)檫@種情況下:

沒有被修改過(guò)的公有代碼或庫(kù)代碼打包出的Entry Chunk,會(huì)隨著其他業(yè)務(wù)代碼的變化而變化,導(dǎo)致頁(yè)面上的長(zhǎng)緩存機(jī)制失效。

那么,下面就來(lái)開啟CommonsChunkPlugin正確的打開方式。

CommonsChunkPlugin不正確用法

假如將我們項(xiàng)目的公共庫(kù)如react、react-dom、react-router與業(yè)務(wù)代碼隔離,將其提取為vendor chunk,webpack配置如下:

const webpack = require("webpack");
const path = require('path');
module.exports = {
 entry: {
 app: "./app.js",
 vendor: ["react","react-dom", "redux", "react-redux", "react-router-redux"]
 },
 output: {
 path: path.resolve(__dirname, 'output'),
 filename: "[name].[chunkhash].js"
 },
 plugins: [
 new webpack.optimize.CommonsChunkPlugin({names: ["vendor"]})
 ]
};

上面將項(xiàng)目一些基礎(chǔ)庫(kù)打包成一個(gè)名為vendor的chunk中,并將業(yè)務(wù)相關(guān)的代碼打包到一個(gè)名為app的chunk中;

webpack打包編譯后的結(jié)果如下:

我們對(duì)其中的業(yè)務(wù)代碼app.js進(jìn)行修改后,重新編譯結(jié)果如下:

可以發(fā)現(xiàn),在CommonsChunkPlugin這種配置下,當(dāng)業(yè)務(wù)代碼app發(fā)生變化,而庫(kù)代碼也跟著變化,vender的chunkhash也跟著變化,這樣vendor的引用的名稱跟著變化,導(dǎo)致瀏覽器端的長(zhǎng)緩存機(jī)制失效。

引起問(wèn)題的原因

引起webpack每次打包編譯時(shí)vendor跟著變化的原因:

webpack每次build的時(shí)候都會(huì)生成一些運(yùn)行時(shí)代碼。當(dāng)只有一個(gè)文件時(shí),運(yùn)行時(shí)代碼直接塞到這個(gè)文件中。當(dāng)有多個(gè)文件時(shí),運(yùn)行時(shí)代碼會(huì)被提取到公共文件中,也就是上面CommonsChunkPlugin配置的vendor chunk中。

webpack每次編譯時(shí)產(chǎn)生的運(yùn)行時(shí)代碼,包括全局webpackJsonp方法的定義和維護(hù)模塊依賴關(guān)系,具體可以參考這里的commons.js。

所以,上面webpack的CommonsChunkPlugin配置中,每次編譯時(shí)這些代碼都會(huì)打包到vendor中,導(dǎo)致每次vendor的chunkhash每次都會(huì)變化。

那么,我們可以在對(duì)vendor chunk進(jìn)行配置,抽取其中的公共代碼,即webpack運(yùn)行時(shí)代碼,這樣就可以將項(xiàng)目依賴的基礎(chǔ)庫(kù)模塊與業(yè)務(wù)模塊隔離開來(lái),因?yàn)椴粫?huì)對(duì)這些文件進(jìn)行修改,所以這些文件可達(dá)到長(zhǎng)緩存的作用。具體配置如下:

module.exports = {
 entry: {
 app: "./app.js",
 vendor: ["react","react-dom", "redux", "react-redux", "react-router-redux"]
 },
 ....
 plugins: [
 new webpack.optimize.CommonsChunkPlugin({names: ["vendor"]}),
 new webpack.optimize.CommonsChunkPlugin({
 name: 'manifest',
 chunks: ['vendor']
 })
 ]
};

這樣,即使修改業(yè)務(wù)app代碼,項(xiàng)目依賴的基礎(chǔ)庫(kù)vendor chunk也不會(huì)發(fā)生變化;只是抽取的manifest chunk每次還會(huì)變化,但是這個(gè)文件體積非常小,相比vendor來(lái)說(shuō)這種方式的收益更大。如下圖:

修改app代碼后的打包編譯結(jié)果如下,可以看到vendor的chunkhash沒有變化

在webpack中配置CommonsChunkPlugin時(shí)需要注意一點(diǎn):

配置webpack的output項(xiàng)時(shí),其filename和chunkFilename必須使用chunkhash。不要使用hash,否則即使按照上面的配置也不能達(dá)到預(yù)期的效果。至于hash與chunkhash的區(qū)別,可參考github的回答

以上這篇簡(jiǎn)單談?wù)凜ommonsChunkPlugin抽取公共模塊就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用php的mail()函數(shù)實(shí)現(xiàn)發(fā)送郵件功能

    使用php的mail()函數(shù)實(shí)現(xiàn)發(fā)送郵件功能

    php中的mail()函數(shù)允許您從腳本中直接發(fā)送電子郵件,下面這篇文章主要給大家介紹了關(guān)于如何使用php的mail()函數(shù)實(shí)現(xiàn)發(fā)送郵件功能的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • 原生js輪播特效

    原生js輪播特效

    這篇文章主要為大家詳細(xì)介紹了原生js輪播特效,簡(jiǎn)單實(shí)用的代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 原生Js頁(yè)面滾動(dòng)延遲加載圖片實(shí)現(xiàn)原理及過(guò)程

    原生Js頁(yè)面滾動(dòng)延遲加載圖片實(shí)現(xiàn)原理及過(guò)程

    頁(yè)面滾動(dòng)加載事件,獲取元素在頁(yè)面里的top值根據(jù)滾動(dòng)條的位置判斷何時(shí)顯示圖片;獲取元素集合 加載過(guò)的圖片從集合里刪除,具體實(shí)現(xiàn)如下,感興趣的朋友各位可以參考下哈
    2013-06-06
  • 淺談JavaScript的innerWidth與innerHeight

    淺談JavaScript的innerWidth與innerHeight

    下面小編就為大家?guī)?lái)一篇淺談JavaScript的innerWidth與innerHeight。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-10-10
  • js 數(shù)組隨機(jī)字符串(廣告不重復(fù))

    js 數(shù)組隨機(jī)字符串(廣告不重復(fù))

    今天一個(gè)網(wǎng)友想讓他的廣告隨機(jī)顯示,每次刷新廣告的內(nèi)容都不一樣,經(jīng)過(guò)參考源碼網(wǎng)站分析就是通過(guò)下面代碼實(shí)現(xiàn),特分享下方便需要的朋友
    2013-08-08
  • 淺析js中事件冒泡與事件捕獲

    淺析js中事件冒泡與事件捕獲

    js中事件冒泡、事件捕獲一直都是困擾大家的問(wèn)題,本文利用大量代碼解釋了js中事件冒泡與事件捕獲,希望對(duì)小伙伴們有所幫助
    2021-08-08
  • 如何使用JS獲取當(dāng)前節(jié)點(diǎn)的兄弟/父/子節(jié)點(diǎn)

    如何使用JS獲取當(dāng)前節(jié)點(diǎn)的兄弟/父/子節(jié)點(diǎn)

    在日常的網(wǎng)頁(yè)開發(fā)中,我們會(huì)遇到獲取節(jié)點(diǎn)的問(wèn)題,而js是寫網(wǎng)頁(yè)的最基礎(chǔ)的語(yǔ)言,也是最常用的,這篇文章主要給大家介紹了關(guān)于如何使用JS獲取當(dāng)前節(jié)點(diǎn)的兄弟/父/子節(jié)點(diǎn)的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • js實(shí)現(xiàn)頁(yè)面圖片消除效果

    js實(shí)現(xiàn)頁(yè)面圖片消除效果

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)頁(yè)面圖片消除效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • js propertychange和oninput事件

    js propertychange和oninput事件

    項(xiàng)目中常遇到輸入框檢查的需求,比如即時(shí)搜索,用change事件?change事件失去焦點(diǎn)才發(fā)生,無(wú)法做到即時(shí)。keypresss事件?能監(jiān)聽到鍵盤,但監(jiān)聽不到鼠標(biāo)復(fù)制粘貼,不完美
    2014-09-09
  • 淺析AMD CMD CommonJS規(guī)范--javascript模塊化加載學(xué)習(xí)心得總結(jié)

    淺析AMD CMD CommonJS規(guī)范--javascript模塊化加載學(xué)習(xí)心得總結(jié)

    下面小編就為大家分享一篇淺析AMD CMD CommonJS規(guī)范--javascript模塊化加載學(xué)習(xí)心得總結(jié)。小編覺得寫的非常不錯(cuò),需要的朋友可以過(guò)來(lái)參考一下
    2016-03-03

最新評(píng)論