DDR爱好者之家 Design By 杰米
本文介绍了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"htmlcode">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 模块热替换,希望对大家的学习有所帮助,也希望大家多多支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
更新日志
2024年11月27日
2024年11月27日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]