webpack热模块替换(HMR)/热更新的方法


Posted in Javascript onApril 05, 2018

这是一篇关于webpack热模块替换的最简单的配置(不需要react),也称作热更新。

模块热替换(HMR)的作用是,在应用运行时,无需刷新页面,便能替换、增加、删除必要的模块。 HMR 对于那些由单一状态树构成的应用非常有用。因为这些应用的组件是 “dumb” (相对于 “smart”) 的,所以在组件的代码更改后,组件的状态依然能够正确反映应用的最新状态。

webpack-dev-server内置“live reload”,会自动刷新页面。

文件目录如下:

  1. app
    1. a.js
    2. component.js
    3. index.js
  2. node_modules
  3. package.json
  4. webpack.config.js

component.js中导入了a.js。index.js导入了component.js。修改任意一个文件,都能达到热更新功能。

最重要的是,在index.js中,有这样一段代码:(完成热更新必须需要)

if(module.hot){
  module.hot.accept(moduleId, callback);
}

下面是package.json配置:

{
 "name": "webpack-hmr",
 "version": "1.0.0",
 "description": "",
 "main": "index.js",
 "scripts": {
  "start": "nodemon --watch webpack.config.js --exec \"webpack-dev-server --env development\"",
  "build": "webpack --env production"
 },
 "keywords": [],
 "author": "",
 "license": "ISC",
 "devDependencies": {
  "html-webpack-plugin": "^2.28.0",
  "nodemon": "^1.11.0",
  "webpack": "^2.2.1",
  "webpack-dev-server": "^2.4.1"
 }
}

从依赖就可以看到,这真的是一个最简单的配置了。其中nodemon用来监听webpack.config.js文件的状态,只要发生改变,就重新执行命令。

关于”html-webpack-plugin”,在这里是可以省略的。具体的配置请看:https://www.npmjs.com/package/html-webpack-plugin 。

在这里,定义了两个命令,一个是start,用于开发环境;一个是build,用于生产环境。--watch用来监听一个或者多个文件,--exec是nodemon用来执行其它的命令。具体的配置请看:https://c9.io/remy/nodemon。

接下来是webpack.config.js了,既然package.json的scripts中定义了两种命令,我们还是要在配置文件中实现两种情况(development和production,你也可以修改配置其中一种)。

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 + '/index.js',
 },
 output: {
  path: PATHS.build,
  filename: '[name].js',
 },
 watch: true,
 plugins: [
  new HtmlWebpackPlugin({
   title: 'Webpack demo',
  }),
 ],
}

function developmentConfig(){
 const config ={
  devServer:{
   historyApiFallback:true, //404s fallback to ./index.html
   // hotOnly:true, 使用hotOnly和hot都可以
   hot: true,
   stats:'errors-only', //只在发生错误时输出
   // host:process.env.Host, 这里是undefined,参考的别人文章有这个
   // port:process.env.PORT, 这里是undefined,参考的别人文章有这个
   overlay:{ //当有编译错误或者警告的时候显示一个全屏overlay
    errors:true,
    warnings:true,
   }
  },
   plugins: [
   new webpack.HotModuleReplacementPlugin(),
   new webpack.NamedModulesPlugin(), // 更新组件时在控制台输出组件的路径而不是数字ID,用在开发模式
   // new webpack.HashedModuleIdsPlugin(), // 用在生产模式
  ],
 };
 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;
};

关于Object.assign,第一个参数是目标对象,如果目标对象中的属性具有相同的键,则属性将被源中的属性覆盖。后来的源的属性将类似地覆盖早先的属性。浅赋值,对于对象的复制使用=,即引用复制。

env参数通过cli传入。

然后打开命令行到当前目录,运行npm start或者npm run build就好啦。注意,前者是在开发环境下,是没有输出文件的(在内存),只有运行后者才会有输出文件。

demo的代码在:https://github.com/yuwanlin/webpackHMR

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery动画特效实例教程
Aug 29 Javascript
BootStrap学习系列之布局组件(下拉,按钮组[toolbar],上拉)
Jan 03 Javascript
原生js实现放大镜效果
Jan 11 Javascript
ajax分页效果(bootstrap模态框)
Jan 23 Javascript
JS+html5 canvas实现的简单绘制折线图效果示例
Mar 13 Javascript
使用selenium抓取淘宝的商品信息实例
Feb 06 Javascript
原生JS实现瀑布流插件
Feb 06 Javascript
JS实现指定区域的全屏显示功能示例
Apr 25 Javascript
微信小程序实现页面跳转传递参数(实体,对象)
Aug 12 Javascript
Vue 自定义指令功能完整实例
Sep 17 Javascript
vue任意关系组件通信与跨组件监听状态vue-communication
Oct 18 Javascript
js基于div丝滑实现贝塞尔曲线
Sep 23 Javascript
详解Vue基于 Nuxt.js 实现服务端渲染(SSR)
Apr 05 #Javascript
express默认日志组件morgan的方法
Apr 05 #Javascript
React Native悬浮按钮组件的示例代码
Apr 05 #Javascript
关于Google发布的JavaScript代码规范你要知道哪些
Apr 04 #Javascript
Angular HMR(热模块替换)功能实现方法
Apr 04 #Javascript
解决vue中使用swiper插件问题及swiper在vue中的用法
Apr 04 #Javascript
vue基于mint-ui实现城市选择三级联动
Jun 30 #Javascript
You might like
什么是短波收听SWL
2021/03/01 无线电
php的一个登录的类 [推荐]
2007/03/16 PHP
PHP面向对象详解(三)
2015/12/07 PHP
thinkPHP分页功能实例详解
2017/05/05 PHP
js类的静态属性和实例属性的理解
2009/10/01 Javascript
通过Javascript将数据导出到外部Excel文档的函数代码
2012/06/15 Javascript
javaScript 动态访问JSon元素示例代码
2013/08/30 Javascript
js获取当前页面路径示例讲解
2014/01/08 Javascript
基于JS实现Android,iOS一个手势动画效果
2016/04/27 Javascript
RequireJS多页面应用实例分析
2016/06/29 Javascript
ES2015 Symbol 一种绝不重复的值
2016/12/25 Javascript
Vue中的数据监听和数据交互案例解析
2017/07/12 Javascript
Angularjs按需查询实例代码
2017/10/30 Javascript
vue项目中api接口管理总结
2018/04/20 Javascript
mpvue构建小程序的方法(步骤+地址)
2018/05/22 Javascript
Vue源码中要const _toStr = Object.prototype.toString的原因分析
2018/12/09 Javascript
详解JavaScript 的变量
2019/03/08 Javascript
一篇文章,教你学会Vue CLI 插件开发
2019/04/17 Javascript
前端路由&webpack基础配置详解
2019/06/10 Javascript
[01:20]DOTA2上海特级锦标赛现场采访:谁的ID最受青睐
2016/03/25 DOTA
[01:33:30]DOTA2-DPC中国联赛 正赛 RNG vs Phoenix BO3 第二场 2月5日
2021/03/11 DOTA
python 从远程服务器下载日志文件的程序
2013/02/10 Python
跟老齐学Python之集合的关系
2014/09/24 Python
利用Python脚本在Nginx和uwsgi上部署MoinMoin的教程
2015/05/05 Python
简单谈谈python中的多进程
2016/11/06 Python
python利用高阶函数实现剪枝函数
2018/03/20 Python
python下解压缩zip文件并删除文件的实例
2018/04/24 Python
ubuntu17.4下为python和python3装上pip的方法
2018/06/12 Python
Python 实现两个列表里元素对应相乘的方法
2018/11/14 Python
提升Python程序性能的7个习惯
2019/04/14 Python
python 获取剪切板内容的两种方法
2020/11/28 Python
高尔夫球鞋、服装、手套和装备:FootJoy
2018/12/15 全球购物
世界上最好的旅行夹克:BauBax
2018/12/23 全球购物
全球高级音频和视频专家:HiDef Lifestyle
2019/08/02 全球购物
波兰品牌鞋履在线商店:Eastend.pl
2020/01/11 全球购物
六十大寿答谢词
2014/01/12 职场文书