詳解react-webpack2-熱模塊替換[HMR]
本文介紹了react-webpack2-熱模塊替換[HMR],分享給大家,具體如下:
模塊熱替換功能會(huì)在應(yīng)用程序運(yùn)行過程中替換、添加或刪除模塊,而無(wú)需重新加載頁(yè)面。這使得你可以在獨(dú)立模塊變更后,無(wú)需刷新整個(gè)頁(yè)面,就可以更新這些模塊,極大地加速了開發(fā)時(shí)間。
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 的環(huán)境打包代碼
// 然后連接到指定服務(wù)器域名與端口,可以換成本機(jī)ip
'webpack/hot/only-dev-server',
// 為熱替換(HMR)打包好代碼
// only- 意味著只有成功更新運(yùn)行代碼才會(huì)執(zhí)行熱替換(HMR)
'./index.js'
// 我們 app 的入口文件
],
vendor: ['react', 'react-router']
// 公共文件打包
}
出口配置 publicPath,(必須配置)
output: {
path: defPath.DEV_PATH,
// 所有輸出文件的目標(biāo)路徑
filename: 'js/bundle.js',
publicPath: '/',
chunkFilename: '[name].chunk.js'
},
plugins 添加相應(yīng)插件
plugins: [
new webpack.HotModuleReplacementPlugin(),
// 開啟全局的模塊熱替換(HMR)
new webpack.NamedModulesPlugin()
// 控制臺(tái)輸出模塊命名美化
]
devServer 配置 HMR
devServer: {
// ... 其他配置
hot: true,
// 開啟服務(wù)器的模塊熱替換(HMR)
contentBase: defPath.DEV_PATH,
// 輸出文件的路徑
publicPath: '/'
// 和 output 的 publicPath 保持一致
}
應(yīng)用代碼中修改
應(yīng)用代碼中需要做很大的改動(dòng)
拆分原入口文件
新建一個(gè)根組件,存放原入口文件中的路由配置部分
/*
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'; // 子級(jí)路由配置
// 創(chuàng)建一個(gè)增強(qiáng)版的history來(lái)結(jié)合store同步導(dǎo)航事件
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 節(jié)點(diǎn)
const mountNode = document.getElementById('app');
// react 的插件,提供onTouchTap()
injectTapEventPlugin();
// 封裝 render 函數(shù)
const render = (Component) => {
ReactDOM.render((
<AppContainer>
<Component/>
</AppContainer>
), mountNode);
};
// 初始化調(diào)用
render(Root);
// 配置需要熱模塊替換的條件
if (module.hot && process.env.NODE_ENV !== 'production') {
// 處理對(duì)特定依賴的更改
module.hot.accept('./containers/Root', (err) => {
if (err) {
console.log(err);
}
// 從DOM 中移除已經(jīng)掛載的 React 組件 然后重裝
ReactDOM.unmountComponentAtNode(mountNode);
render(Root);
});
}
以上就可以使用 webpack 2 模塊熱替換,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
解決React報(bào)錯(cuò)Functions are not valid as 
這篇文章主要為大家介紹了React報(bào)錯(cuò)Functions are not valid as a React child解決詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
React實(shí)現(xiàn)前端選區(qū)的示例代碼
本文主要介紹了React實(shí)現(xiàn)前端選區(qū)的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
React Native 自定義下拉刷新上拉加載的列表的示例
本篇文章主要介紹了React Native 自定義下拉刷新上拉加載的列表的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-03-03
React自定義視頻全屏按鈕實(shí)現(xiàn)全屏功能
這篇文章主要介紹了React自定義視頻全屏按鈕實(shí)現(xiàn)全屏功能,通過繪制全屏按鈕,并綁定點(diǎn)擊事件,編寫點(diǎn)擊事件,通過實(shí)例代碼給大家詳細(xì)講解,需要的朋友可以參考下2022-11-11
React函數(shù)式組件Hook中的useEffect函數(shù)的詳細(xì)解析
useEffect是react v16.8新引入的特性。我們可以把useEffect hook看作是componentDidMount、componentDidUpdate、componentWillUnmounrt三個(gè)函數(shù)的組合2022-10-10
react hooks使用Echarts圖表中遇到的情況及相關(guān)配置問題
這篇文章主要介紹了react hooks使用Echarts圖表中遇到的情況及相關(guān)配置問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03

