全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

本文介绍了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 模块热替换,希望对大家的学习有所帮助,也希望大家多多支持。


# webpack2  # react热替换  # webpack  # react  # 热替换  # 浅谈Webpack多页应用HMR卡住问题  # webpack热模块替换(HMR)/热更新的方法  # 详解webpack2+node+react+babel实现热加载(hmr)  # webpack几种手动实现HMR的方式  # 就可以  # 加载  # 你可以  # 才会  # 会在  # 给大家  # 或删除  # 本机  # 重装  # 增强版  # 连接到  # 创建一个  # 大家多多  # 移除  # 过程中  # 新建一个  # 应用程序  # 极大地  # 这使得  # patch 


相关文章: 北京制作网站的公司,北京铁路集团官方网站?  建站主机默认首页配置指南:核心功能与访问路径优化  网站按钮制作软件,如何实现网页中按钮的自动点击?  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  如何选择高效可靠的多用户建站源码资源?  深圳网站制作培训,深圳哪些招聘网站比较好?  网站制作价目表怎么做,珍爱网婚介费用多少?  大连网站设计制作招聘信息,大连投诉网站有哪些?  定制建站哪家更专业可靠?推荐榜单揭晓  Thinkphp 中 distinct 的用法解析  建站之星ASP如何实现CMS高效搭建与安全管理?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何在万网开始建站?分步指南解析  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  公司网站的制作公司,企业网站制作基本流程有哪些?  广平建站公司哪家专业可靠?如何选择?  如何在景安服务器上快速搭建个人网站?  ,sp开头的版面叫什么?  建站主机选哪种环境更利于SEO优化?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  如何选购建站域名与空间?自助平台全解析  C#如何在一个XML文件中查找并替换文本内容  网站制作难吗安全吗,做一个网站需要多久时间?  如何用VPS主机快速搭建个人网站?  Python文件管理规范_工程实践说明【指导】  小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  北京企业网站设计制作公司,北京铁路集团官方网站?  建站主机系统SEO优化与智能配置核心关键词操作指南  免费ppt制作网站,有没有值得推荐的免费PPT网站?  如何续费美橙建站之星域名及服务?  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  定制建站策划方案_专业建站与网站建设方案一站式指南  电商网站制作价格怎么算,网上拍卖流程以及规则?  高性价比服务器租赁——企业级配置与24小时运维服务  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  手机网站制作与建设方案,手机网站如何建设?  制作旅游网站html,怎样注册旅游网站?  制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?  如何注册花生壳免费域名并搭建个人网站?  如何在云主机上快速搭建网站?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  网页设计与网站制作内容,怎样注册网站?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  如何通过西部数码建站助手快速创建专业网站?  定制建站是什么?如何实现个性化需求?  如何快速生成可下载的建站源码工具?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  如何快速生成凡客建站的专业级图册? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。