本文介绍了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 模块热替换,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。