详解react-webpack2-热模块替换[HMR]
程序员文章站
2024-01-24 14:15:04
本文介绍了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 模块热替换,希望对大家的学习有所帮助,也希望大家多多支持。