使用webpack打包,難免會使用Hot Module Replacement功能,該功能能夠實現(xiàn)修改、添加或刪除前端頁面中的模塊代碼,而且是在頁面不刷新的前提下。它究竟是怎么運作的呢?本文主要從調試工具、配置文件、官方文檔三個方面進行解析。

調試工具

首先從chrome的調試工具network中看看,代碼改變的時候,頁面與后端之間發(fā)生了什么?

頁面初始加載

我們看到除了加載頁面所依賴的文件外,多了一個連接,這是一個Server-sent Events,相關的介紹可以參考這篇文章,而且每隔一段時間都會向發(fā)送一次數(shù)據(jù)。數(shù)據(jù)內容主要是

action:sync操作;

hash:f397e485c539fd7a10fb,是bundle的hash,因為和產出文件collections.f397e485c539fd7a10fbjs的內容hash值相同;

modules:產出bundle中的module id和對應的文件地址。

網(wǎng)友評論