亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

webpack 模塊熱替換原理

2024-05-06 16:43:39
字體:
來源:轉載
供稿:網友

全稱是Hot Module ReplaceMent(HMR),理解成熱模塊替換或者模塊熱替換都可以吧,和.net中的熱插拔一個意思,就是在運行中對程序的模塊進行更新。這個功能主要是用于開發過程中,對生產環境沒有任何幫助(這一點區別.net熱插拔)。效果上就是界面的無刷新更新。

HMR基于WDS,style-loader可以通過它來實現無刷新更新樣式。但是對于JavaScript模塊就需要做一點額外的處理,怎么處理繼續往下看。因為HMR是用于開發環境的,所以我們修改下配置,做兩份準備。一個用于生產,一個用于開發。

const path = require('path');const HtmlWebpackPlugin = require('html-webpack-plugin');const webpack = require('webpack');const PATHS = { app: path.join(__dirname, 'app'), build: path.join(__dirname, 'build'),};const commonConfig={ entry: {  app: PATHS.app, }, output: {  path: PATHS.build,  filename: '[name].js', }, plugins: [  new HtmlWebpackPlugin({   title: 'Webpack demo',  }), ],} function developmentConfig(){ const config ={  devServer:{   //使能歷史記錄api   historyApiFallback:true,    hotOnly:true,//關閉熱替換 注釋掉這行就行    stats:'errors-only',   host:process.env.Host,   port:process.env.PORT,   overlay:{    errors:true,    warnings:true,   }  },   plugins: [   new webpack.HotModuleReplacementPlugin(),  ], };  return Object.assign(  {},  commonConfig,  config,  {   plugins: commonConfig.plugins.concat(config.plugins),  } );}module.exports = function(env){ console.log("env",env); if(env=='development'){  return developmentConfig(); }  return commonConfig;};

這個webpack.config.js建立了兩個配置,一個是commonConfig,一個是developmentConfig 兩者通過env參數來區分,但這個env參數是怎么來的呢?我們看看之前的package.json中的一段:

webpack,模塊熱替換,熱替換,原理

也就是說,如果按照上面的這個配置,我們通過npm start 啟動的話,進入的就是開發環境配置,如果是直接build,那么就是生產環境的方式。build方式是第一節里面講的 直接通過npm啟動webpack,這就不帶WDS了。另外有了一個Object.assign語法,將配置合并。這個時候通過npm start啟動,控制臺打印出了兩條日志。

webpack,模塊熱替換,熱替換,原理

看起來HRM已經啟動了。但是此時更新一下component.js

webpack,模塊熱替換,熱替換,原理

日志顯示沒有東西被熱更新。而且這個39,36代表的是模塊Id,看起來很不直觀,這里可以通過一個插件使其更符合人意

plugins: [   new webpack.HotModuleReplacementPlugin(),    new webpack.NamedModulesPlugin(),  ],

這個時候再啟動。

webpack,模塊熱替換,熱替換,原理

這樣名稱就直觀了。但是我們期待的更新還是沒有出來。因為需要實現一個接口

import component from './component';let demoComponent=component();document.body.appendChild(demoComponent);//HMR 接口if(module.hot){  module.hot.accept('./component',()=>{    const nextComponent=component();    document.body.replaceChild(nextComponent,demoComponent);    demoComponent=nextComponent;  })}

并修改component.js:

export default function () { var element = document.createElement('h1'); element.innerHTML = 'Hello webpack'; return element;}

webpack,模塊熱替換,熱替換,原理

這個時候頁面更新了。每次改動頁面上都會增加一個帶有hot-update.js ,類似于下面這樣:

webpackHotUpdate(0,{/***/ "./app/component.js":/***/ (function(module, __webpack_exports__, __webpack_require__) {"use strict";Object.defineProperty(__webpack_exports__, "__esModule", { value: true });/* harmony default export */ __webpack_exports__["default"] = function () { var element = document.createElement('h1'); element.innerHTML = 'Hello web '; element.className='box'; return element;};/***/ })})

通過webpackHotUpdate對相應模塊進行更新。0表示模塊的id,"./app/component.js"表示模塊對應的name。結構是webpack(id,{key:function(){}})。function外帶了一個括號,不知道有什么作用。webpackHotUpdate的定義是這樣的:

this["webpackHotUpdate"] =  function webpackHotUpdateCallback(chunkId, moreModules) { // eslint-disable-line no-unused-vars       hotAddUpdateChunk(chunkId, moreModules);    if(parentHotUpdateCallback) parentHotUpdateCallback(chunkId, moreModules);  } ;

小結:從結構來看,一個是id,一個是對應修改的模塊。但實際執行更新的是hotApply方法。熱更新整個機制還是有點復雜,效果上像MVVM的那種綁定。有興趣的可以深入研究下。不建議在生產使用HMR,會讓整體文件變大,而且對生成沒有什么幫助,在下一節會講樣式的加載,style-loader就是用到了HMR。但對于js模塊還要寫額外的代碼,這讓人有點不爽。

demo:webpack-ch3.rar

參考:

https://survivejs.com/webpack/developing/configuring-hmr/

https://webpack.js.org/configuration/dev-server/

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久五月情影视| 欧美亚洲在线播放| 亚洲区bt下载| 亚洲欧美日韩图片| 欧美—级a级欧美特级ar全黄| 97av视频在线| 一区二区国产精品视频| 精品国产91久久久| 亚洲欧美制服中文字幕| 精品偷拍一区二区三区在线看| www国产91| 日韩视频在线免费| 亚洲激情自拍图| 亚洲成人激情小说| 久久九九国产精品怡红院| 欧美日韩国产综合视频在线观看中文| 国产精品综合久久久| 韩日欧美一区二区| 日韩中文视频免费在线观看| 亚洲精品白浆高清久久久久久| 2020国产精品视频| 日韩av手机在线| 日韩专区中文字幕| 中文字幕日韩欧美精品在线观看| 久久久久久久久久国产精品| 91九色精品视频| 欧美激情在线播放| 国产精品美女久久久久av超清| 国产精品久久99久久| 午夜精品一区二区三区在线播放| 欧美日韩一区二区精品| 国产精品一区专区欧美日韩| 精品久久久香蕉免费精品视频| 国产精品手机播放| 91视频国产精品| 国产欧美日韩视频| 亚洲高清免费观看高清完整版| 91av在线免费观看| 欧美中文在线观看| 日韩在线观看网址| 久久精品中文字幕| 欧美在线影院在线视频| 日本久久久久久| 成人两性免费视频| 国产精品一区久久| 亚洲国产精品久久久| 美日韩丰满少妇在线观看| 中文字幕v亚洲ⅴv天堂| 久久视频免费在线播放| 精品自拍视频在线观看| 成人欧美一区二区三区黑人孕妇| 亚洲国产欧美一区二区三区同亚洲| 日韩电影中文字幕在线观看| 久久久久久久久久久久久久久久久久av| 精品国产一区二区三区久久久狼| 中文字幕不卡av| 久久久久在线观看| 在线亚洲欧美视频| 精品久久香蕉国产线看观看gif| 中文字幕自拍vr一区二区三区| 成人国产精品日本在线| 色偷偷偷亚洲综合网另类| 色噜噜狠狠狠综合曰曰曰88av| 亚洲国产黄色片| 亚洲国产91精品在线观看| 日韩欧美精品中文字幕| 亚洲欧美另类自拍| www.日韩不卡电影av| 国产视频久久久久| 日韩少妇与小伙激情| 91免费看视频.| 亚洲第一色中文字幕| 欧美丝袜第一区| 欧美电影在线播放| 中文字幕日韩av电影| 国产香蕉精品视频一区二区三区| 国产精品一区久久久| 欧美亚州一区二区三区| 成人在线精品视频| 欧美插天视频在线播放| 国产精品专区h在线观看| 久久成人av网站| 在线观看精品自拍私拍| 国产视频久久网| 亚洲国产精品一区二区久| 中文字幕亚洲无线码在线一区| 日韩av在线网| 欧美久久精品午夜青青大伊人| 欧美性猛交xxxx黑人猛交| 81精品国产乱码久久久久久| 久久亚洲精品毛片| 久久艳片www.17c.com| 亚洲男人天堂久| 九九精品在线播放| www.日本久久久久com.| 精品调教chinesegay| 亚洲日韩中文字幕| 国产精品极品尤物在线观看| 国产精彩精品视频| 6080yy精品一区二区三区| 在线精品91av| 欧美高清第一页| 国产成人短视频| 日韩精品久久久久久福利| 国产69精品久久久久9| 国产精品91久久| 成人网在线免费观看| 欧美又大又硬又粗bbbbb| 91精品中文在线| 亚洲毛片在线观看.| 欧美午夜激情视频| 亚洲成人av资源网| 日韩欧美精品免费在线| 国产有码在线一区二区视频| 少妇高潮久久久久久潘金莲| 日韩视频永久免费观看| 中文字幕精品久久久久| 91理论片午午论夜理片久久| 国产精品69av| 97涩涩爰在线观看亚洲| 精品视频9999| 91探花福利精品国产自产在线| 欧美另类在线播放| 26uuu国产精品视频| 91精品在线播放| 日韩国产精品亚洲а∨天堂免| 亚洲免费视频在线观看| 亚洲va久久久噜噜噜| 青青久久av北条麻妃海外网| 免费不卡在线观看av| 国产视频精品在线| 在线视频一区二区| 欧美国产日韩一区二区三区| 亚洲一区二区中文| 91av免费观看91av精品在线| 国产伦精品一区二区三区精品视频| 亚洲石原莉奈一区二区在线观看| 色婷婷综合成人| 成人羞羞国产免费| 日本久久精品视频| 国产亚洲精品激情久久| 日韩欧美中文字幕在线播放| 国产成人精品一区| 日韩精品免费视频| 青草青草久热精品视频在线观看| www.久久撸.com| 国产在线高清精品| 欧美色另类天堂2015| 国产精品永久免费视频| 亚洲乱码一区av黑人高潮| 亚洲精品mp4| 欧美电影免费观看电视剧大全| 一本色道久久88综合日韩精品| 午夜精品视频在线| 欧洲美女7788成人免费视频| 疯狂做受xxxx欧美肥白少妇| 欧美最顶级的aⅴ艳星| 欧美成人精品在线视频| 亚洲人成免费电影| 亚洲国产精久久久久久| 午夜免费在线观看精品视频| 亚洲理论在线a中文字幕| 国产精品日韩久久久久| 最近免费中文字幕视频2019|