詳解react-webpack2-熱模塊替換[HMR]
本文介紹了react-webpack2-熱模塊替換[HMR],分享給大家,具體如下:
模塊熱替換功能會(huì)在應(yīng)用程序運(yùn)行過程中替換、添加或刪除模塊,而無需重新加載頁面。這使得你可以在獨(dú)立模塊變更后,無需刷新整個(gè)頁面,就可以更新這些模塊,極大地加速了開發(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'; // 子級路由配置 // 創(chuàng)建一個(gè)增強(qiáng)版的history來結(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') { // 處理對特定依賴的更改 module.hot.accept('./containers/Root', (err) => { if (err) { console.log(err); } // 從DOM 中移除已經(jīng)掛載的 React 組件 然后重裝 ReactDOM.unmountComponentAtNode(mountNode); render(Root); }); }
以上就可以使用 webpack 2 模塊熱替換,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
React教程之Props驗(yàn)證的具體用法(Props Validation)
這篇文章主要介紹了React教程之Props驗(yàn)證的具體用法(Props Validation),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-09-09react PropTypes校驗(yàn)傳遞的值操作示例
這篇文章主要介紹了react PropTypes校驗(yàn)傳遞的值操作,結(jié)合實(shí)例形式分析了react PropTypes針對傳遞的值進(jìn)行校驗(yàn)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2020-04-04react實(shí)現(xiàn)列表滾動(dòng)組件功能
在開發(fā)項(xiàng)目的時(shí)候,從服務(wù)端獲取到數(shù)據(jù)列表后,展示給用戶看,需要實(shí)現(xiàn)數(shù)據(jù)自動(dòng)滾動(dòng)效果,怎么實(shí)現(xiàn)呢,下面小編給大家分享react實(shí)現(xiàn)列表滾動(dòng)組件功能實(shí)現(xiàn)代碼,感興趣的朋友一起看看吧2023-09-09React替換傳統(tǒng)拷貝方法的Immutable使用
Immutable.js出自Facebook,是最流行的不可變數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)之一。它實(shí)現(xiàn)了完全的持久化數(shù)據(jù)結(jié)構(gòu),使用結(jié)構(gòu)共享。所有的更新操作都會(huì)返回新的值,但是在內(nèi)部結(jié)構(gòu)是共享的,來減少內(nèi)存占用2023-02-02React的createElement和render手寫實(shí)現(xiàn)示例
這篇文章主要為大家介紹了React的createElement和render手寫實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08react-native?父函數(shù)組件調(diào)用類子組件的方法(實(shí)例詳解)
這篇文章主要介紹了react-native?父函數(shù)組件調(diào)用類子組件的方法,通過詳細(xì)步驟介紹了React 函數(shù)式組件之父組件調(diào)用子組件的方法,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09React Native 集成 ArcGIS 地圖的詳細(xì)過程
ArcGIS官方提供了 JavaScript SDK,也提供了 ArcGIS-Runtime-SDK-iOS,但是并沒有提供 React Native的版本,所以這里使用了 react-native-arcgis-mapview 庫,本文給大家介紹React Native 集成 ArcGIS 地圖的詳細(xì)過程,感興趣的朋友跟隨小編一起看看吧2024-06-06詳解React項(xiàng)目中eslint使用百度風(fēng)格
這篇文章主要介紹了React項(xiàng)目中eslint使用百度風(fēng)格,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09