时间:2021-05-25
本文介绍了react-webpack2-热模块替换[HMR],分享给大家,具体如下:
模块热替换功能会在应用程序运行过程中替换、添加或删除模块,而无需重新加载页面。这使得你可以在独立模块变更后,无需刷新整个页面,就可以更新这些模块,极大地加速了开发时间。
babel 配置
需要先下载 npm install --save-dev react-hot-loader@3.0.0-beta.6
然后在 .babelrc 中配置
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 保持一致 }应用代码中修改
应用代码中需要做很大的改动
拆分原入口文件
新建一个根组件,存放原入口文件中的路由配置部分
原入口文件改为
以上就可以使用 webpack 2 模块热替换,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
模块热替换(HotModuleReplacement)HMR是webpack最令人兴奋的特性之一,当你对代码进行修改并保存后,webpack将对代码重新打包,并
全称是HotModuleReplaceMent(HMR),理解成热模块替换或者模块热替换都可以吧,和.net中的热插拔一个意思,就是在运行中对程序的模块进行更新
本文介绍了详解Angular5/Angular6项目如何添加热更新(HMR)功能,分享给大家,具体如下:A:什么是HMR?Q:HMR(热替换)用于在运行的应用程
上一篇介绍了如何使用webpack搭建一个稳定的支持本地服务、自动刷新、模块热替换、使用ES6编写JavaScript的开发环境,本篇主要介绍webpack如何
本文介绍了React全家桶环境搭建过程详解,分享给大家,具体如下:环境搭建1.从零开始搭建webpack+react开发环境2.引入Typescript安装依赖