webpack熱更新

使用webpack可幫助我們的開(kāi)發(fā)以及打包络断,在開(kāi)發(fā)過(guò)程中,有時(shí)候我們只修改了部分代碼并想不必刷新整個(gè)頁(yè)面即可看到更改后的效果粘衬,這時(shí)候 webpack-dev-server (WDS)熱更新就可以派上用場(chǎng)了荞估。

關(guān)于 WDS 熱更新咳促,有以下幾點(diǎn):
(1)WDS 不刷新整個(gè)頁(yè)面;
(2)WDS 不輸出文件勘伺,而放在內(nèi)存中(沒(méi)有磁盤(pán)IO跪腹,速度更快);
(3)使用 HotModuleReplacementPlugin 插件(webpack自帶)飞醉。

WDS需要先通過(guò) npm 安裝 webpack-dev-server冲茸,然后相關(guān)配置如下:

const devServer = {
 port: 8000,
 host: '0.0.0.0',
 hot: true //熱更新,修改代碼后缅帘,不刷新整個(gè)頁(yè)面
}

// plugin 中需要使 HotModuleReplacementPlugin插件
plugins:defaultPluins.concat([
     new webpack.HotModuleReplacementPlugin()   
])

熱更新的原理分析:##

熱更新原理圖(from Geekbang)

HMR Runtime:開(kāi)發(fā)的打包階段被注入到瀏覽器端的 Bundle.js 里轴术,這樣 bundle.js 就建立起和服務(wù)器的連接(websocket連接),這樣在編輯器中修改代碼钦无,相應(yīng)的文件變化就可以得到及時(shí)更新逗栽。
熱更新的過(guò)程,還是看上面那張圖:
(1)啟動(dòng)階段:文件系統(tǒng)中的代碼經(jīng)過(guò) webpack compiler 編譯失暂,打包輸出為 bundle.js祭陷,并傳輸給 Bundle Server,使 瀏覽器能通過(guò)訪(fǎng)問(wèn)服務(wù)器獲取 bundle.js. (圖中過(guò)程為 1趣席,2兵志,A,B);
(2) 更新階段:改動(dòng)的代碼還是經(jīng)過(guò) webpack compiler 編譯宣肚,然后傳給 HMR Server(知道js代碼中 哪些模塊發(fā)生了改變)想罕,HMR Server 再去通知瀏覽器端的 HMR Runtime 哪些內(nèi)容發(fā)生了變化(以 json 數(shù)據(jù)方式傳輸通知),然后 HMR Runtime 就會(huì)更新代碼霉涨,最后頁(yè)面上就會(huì)呈現(xiàn)相應(yīng)的改變按价。(圖中過(guò)程為 1,2笙瑟,3楼镐,4,5)

最后提下往枷,還可使用 webpack-dev-middleware(WDM)來(lái)進(jìn)行熱更新框产,將 webpack 輸出的文件傳輸給服務(wù)器,適用于靈活的定制場(chǎng)景错洁。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末秉宿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子屯碴,更是在濱河造成了極大的恐慌描睦,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件导而,死亡現(xiàn)場(chǎng)離奇詭異忱叭,居然都是意外死亡隔崎,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)韵丑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)仍稀,“玉大人,你說(shuō)我怎么就攤上這事埂息〖寂耍” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵千康,是天一觀(guān)的道長(zhǎng)享幽。 經(jīng)常有香客問(wèn)我,道長(zhǎng)拾弃,這世上最難降的妖魔是什么值桩? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮豪椿,結(jié)果婚禮上奔坟,老公的妹妹穿的比我還像新娘。我一直安慰自己搭盾,他們只是感情好咳秉,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著鸯隅,像睡著了一般澜建。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蝌以,一...
    開(kāi)封第一講書(shū)人閱讀 49,772評(píng)論 1 290
  • 那天炕舵,我揣著相機(jī)與錄音,去河邊找鬼跟畅。 笑死咽筋,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的徊件。 我是一名探鬼主播奸攻,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼庇忌!你這毒婦竟也來(lái)了舞箍?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤皆疹,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后占拍,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體略就,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡捎迫,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了表牢。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片窄绒。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖崔兴,靈堂內(nèi)的尸體忽然破棺而出彰导,到底是詐尸還是另有隱情,我是刑警寧澤敲茄,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布位谋,位于F島的核電站,受9級(jí)特大地震影響堰燎,放射性物質(zhì)發(fā)生泄漏掏父。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一秆剪、第九天 我趴在偏房一處隱蔽的房頂上張望赊淑。 院中可真熱鬧,春花似錦仅讽、人聲如沸陶缺。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)组哩。三九已至,卻和暖如春处渣,著一層夾襖步出監(jiān)牢的瞬間伶贰,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工罐栈, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留黍衙,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓荠诬,卻偏偏與公主長(zhǎng)得像琅翻,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子柑贞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 想必作為前端大佬的你方椎,工作中應(yīng)該用過(guò) webpack,并且對(duì)熱更新的特性也有了解钧嘶。如果沒(méi)有棠众,當(dāng)然也沒(méi)關(guān)系。 下面我...
    NARUTO_86閱讀 8,617評(píng)論 2 5
  • 概述 在使用 Webpack 構(gòu)建開(kāi)發(fā)期時(shí),Webpack 提供熱更新功能為開(kāi)發(fā)帶來(lái)良好的體驗(yàn)和開(kāi)發(fā)效率闸拿,那熱更新...
    hubcarl閱讀 27,373評(píng)論 5 23
  • webpack 介紹 webpack 是什么 為什么引入新的打包工具 webpack 核心思想 webpack 安...
    yxsGert閱讀 6,458評(píng)論 2 71
  • 前言 webpack-dev-server配置熱更新看起來(lái)很簡(jiǎn)單空盼,但是實(shí)際上是有很多坑的,目前為止我沒(méi)有搜到一篇深...
    大柚子08閱讀 12,661評(píng)論 23 27
  • 我們?cè)谟脀ebpack打包文件新荤,如果打包出來(lái)的資源是帶有哈希值揽趾,每打一次包,就會(huì)出現(xiàn)一個(gè)不同哈希值的文件苛骨。為了避免...
    demo11閱讀 1,110評(píng)論 0 0