首頁 > web前端 > js教程 > 主體

webpack的模組熱替換詳解

php中世界最好的语言
發布: 2018-03-16 11:24:32
原創
2165 人瀏覽過

這次帶給大家webpack的模組熱替換詳解,使用webpack模組熱替換的注意事項有哪些,下面就是實戰案例,一起來看一下。

全名是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中的一段:

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

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

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

 plugins: [      new webpack.HotModuleReplacementPlugin(),       new webpack.NamedModulesPlugin(),
    ],
登入後複製

這時候再啟動。

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

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;
}
登入後複製

##這個時候頁面更新了。每次改動頁面上都會增加一個帶有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的定義是這樣的:

["webpackHotUpdate"] = 
   webpackHotUpdateCallback(chunkId, moreModules) {            } ;
登入後複製
從結構來看,一個是id,一個是對應修改的模組。但實際執行更新的是hotApply方法。熱更新整個機制還是有點複雜,效果上像是MVVM的那種綁定。有興趣的可以深入研究下。不建議在生產使用HMR,會讓整體檔案變大,而且對生成沒有什麼幫助,在下一節會講樣式的加載,style-loader就是用到了HMR。但對於js模組還要寫額外的程式碼,讓人有點不爽。

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

webpack的樣式載入詳解

#JS事件先發布後訂閱的方法

vue2全家桶是什麼,如何使用?
#

以上是webpack的模組熱替換詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!