详解react-webpack2-热模块替换[HMR]


Posted in Javascript onAugust 03, 2017

本文介绍了react-webpack2-热模块替换[HMR],分享给大家,具体如下:

模块热替换功能会在应用程序运行过程中替换、添加或删除模块,而无需重新加载页面。这使得你可以在独立模块变更后,无需刷新整个页面,就可以更新这些模块,极大地加速了开发时间。

babel 配置

需要先下载 npm install --save-dev react-hot-loader@3.0.0-beta.6

然后在 .babelrc 中配置

{
 "presets": [
  ["es2015", {"modules": false}], // webpack 2 中需要这样配置禁用

  "stage-2",

  "react"
 ],
 "plugins": [
  "react-hot-loader/babel"
  // 开启 React 代码的模块热替换(HMR)
 ]
}

webpack 配置

入口插入模块热替换

entry: {
    app: [
      'react-hot-loader/patch',
      // 开启 React 代码的模块热替换(HMR)

      'webpack-dev-server/client?http://localhost:8080',
      // 为 webpack-dev-server 的环境打包代码
      // 然后连接到指定服务器域名与端口,可以换成本机ip

      'webpack/hot/only-dev-server',
      // 为热替换(HMR)打包好代码
      // only- 意味着只有成功更新运行代码才会执行热替换(HMR)


      './index.js'
      // 我们 app 的入口文件
    ],
    vendor: ['react', 'react-router']
    // 公共文件打包
  }

出口配置 publicPath,(必须配置)

output: {
    path: defPath.DEV_PATH,
    // 所有输出文件的目标路径

    filename: 'js/bundle.js',

    publicPath: '/',

    chunkFilename: '[name].chunk.js'
  },

plugins 添加相应插件

plugins: [
    new webpack.HotModuleReplacementPlugin(),
    // 开启全局的模块热替换(HMR)

    new webpack.NamedModulesPlugin()
    // 控制台输出模块命名美化
  ]

devServer 配置 HMR

devServer: {
    // ... 其他配置

    hot: true,
    // 开启服务器的模块热替换(HMR)

    contentBase: defPath.DEV_PATH,
    // 输出文件的路径

    publicPath: '/'
    // 和 output 的 publicPath 保持一致
  }

应用代码中修改

应用代码中需要做很大的改动

拆分原入口文件

新建一个根组件,存放原入口文件中的路由配置部分

/*
    Root, Router 配置
  */
  import React from 'react';
  import {Provider} from 'react-redux';
  import {browserHistory, Router} from 'react-router';
  import {syncHistoryWithStore} from 'react-router-redux';


  import store from '../store/index'; // 引入 配置后的 store 
  import routes from '../routes.js'; // 子级路由配置

  // 创建一个增强版的history来结合store同步导航事件
  const browhistory = syncHistoryWithStore(browserHistory, store);

  const Root = () => (
    <Provider store={store}>
     <div>
       <Router history={browhistory} routes={routes}/>
     </div>
    </Provider>
  );


  export default Root;

原入口文件改为

/*
    app/js/index.js
    入口文件, 配置 webpack 热加载模块
  */
  import '../scss/index.scss';
  import '../scss/commoncom.scss';

  import React from 'react';
  import ReactDOM from 'react-dom';
  import {AppContainer} from 'react-hot-loader'; 
  // 引入 react-hot-loader 提供的容器
  import injectTapEventPlugin from 'react-tap-event-plugin';

  // 引入总路由的配置模块
  import Root from './containers/Root';

  // 定义要挂载的 DOM 节点
  const mountNode = document.getElementById('app');

  // react 的插件,提供onTouchTap()
  injectTapEventPlugin();

  // 封装 render 函数
  const render = (Component) => {
    ReactDOM.render((
      <AppContainer>
        <Component/>
      </AppContainer>
    ), mountNode);
  };

  // 初始化调用
  render(Root);

  // 配置需要热模块替换的条件
  if (module.hot && process.env.NODE_ENV !== 'production') {
    // 处理对特定依赖的更改
    module.hot.accept('./containers/Root', (err) => {
      if (err) {
        console.log(err);
      }
      // 从DOM 中移除已经挂载的 React 组件 然后重装
      ReactDOM.unmountComponentAtNode(mountNode);
      render(Root);
    });
  }

以上就可以使用 webpack 2 模块热替换,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery实战之品牌展示列表效果
Apr 10 Javascript
javascript面向对象之共享成员属性与方法及prototype关键字用法
Jan 13 Javascript
js实现卡片式项目管理界面UI设计效果
Dec 08 Javascript
jQuery插件EasyUI设置datagrid的checkbox为禁用状态的方法
Aug 05 Javascript
js实现表格筛选功能
Jan 18 Javascript
微信小程序之picker日期和时间选择器
Feb 09 Javascript
使用vue-aplayer插件时出现的问题的解决
Mar 02 Javascript
webpack vue项目开发环境局域网访问方法
Mar 20 Javascript
Vue框架里使用Swiper的方法示例
Sep 20 Javascript
JavaScript 中的六种循环方法
Jan 06 Javascript
Vue全家桶入门基础教程
May 14 Vue.js
JS前端使用canvas实现扩展物体类和事件派发
Aug 05 Javascript
webpack开发跨域问题解决办法
Aug 03 #Javascript
详解Vuejs2.0 如何利用proxyTable实现跨域请求
Aug 03 #Javascript
react-native ListView下拉刷新上拉加载实现代码
Aug 03 #Javascript
解决ionic和angular上拉加载的问题
Aug 03 #Javascript
ES6学习教程之Map的常用方法总结
Aug 03 #Javascript
微信小程序之电影影评小程序制作代码
Aug 03 #Javascript
Form表单上传文件(type=&quot;file&quot;)的使用
Aug 03 #Javascript
You might like
个人站长制做网页常用的php代码
2007/03/03 PHP
php 常用字符串函数总结
2008/03/15 PHP
PHP+MYSQL 出现乱码的解决方法
2008/08/08 PHP
ThinkPHP调试模式与日志记录概述
2014/08/22 PHP
PHP查看SSL证书信息的方法
2016/09/22 PHP
Thinkphp5+plupload实现的图片上传功能示例【支持实时预览】
2019/05/08 PHP
PHP实现简单用户登录界面
2019/10/23 PHP
处理及遍历XML文档DOM元素属性及方法整理
2013/08/23 Javascript
跟我学习javascript的prototype原型和原型链
2015/11/18 Javascript
Bootstrap每天必学之表单
2015/11/23 Javascript
js组件SlotMachine实现图片切换效果制作抽奖系统
2016/04/17 Javascript
基于jQuery下拉选择框插件支持单选多选功能代码
2016/06/07 Javascript
webix+springmvc session超时跳转登录页面
2016/10/30 Javascript
vue实现单选和多选功能
2017/08/11 Javascript
谈谈为什么你的 JavaScript 代码如此冗长
2019/01/30 Javascript
layui 对弹窗 form表单赋值的实现方法
2019/09/04 Javascript
Vue3为什么这么快
2020/09/23 Javascript
Python实现将绝对URL替换成相对URL的方法
2015/06/28 Python
Django小白教程之Django用户注册与登录
2016/04/22 Python
解决使用pycharm提交代码时冲突之后文件丢失找回的方法
2018/08/05 Python
解决python中 f.write写入中文出错的问题
2018/10/31 Python
python+selenium实现QQ邮箱自动发送功能
2019/01/23 Python
PyQt弹出式对话框的常用方法及标准按钮类型
2019/02/27 Python
详解Python3中setuptools、Pip安装教程
2019/06/18 Python
python中pip的使用和修改下载源的方法
2019/07/08 Python
input元素的url类型和email类型简介
2012/07/11 HTML / CSS
英国发展最快的在线超市之一:Click Marketplace
2021/02/15 全球购物
Python中pass语句的作用是什么
2016/06/01 面试题
大学毕业生自我鉴定
2013/11/05 职场文书
如何写自我评价?自我评价写什么好?
2014/03/14 职场文书
家居装修公司创业计划书范文
2014/03/20 职场文书
个人主要事迹材料
2014/08/26 职场文书
异地年检委托书范本
2014/09/24 职场文书
Memcached介绍及php-memcache扩展安装
2021/04/01 PHP
用Python生成会跳舞的美女
2022/01/18 Python
win10如何快速切换窗口 win10切换窗口快捷键分享
2022/07/23 数码科技