欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解react-webpack2-熱模塊替換[HMR]

 更新時間:2017年08月03日 11:43:05   作者:mjzhang1993  
這篇文章主要介紹了詳解react-webpack2-熱模塊替換[HMR], 小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

本文介紹了react-webpack2-熱模塊替換[HMR],分享給大家,具體如下:

模塊熱替換功能會在應(yīng)用程序運行過程中替換、添加或刪除模塊,而無需重新加載頁面。這使得你可以在獨立模塊變更后,無需刷新整個頁面,就可以更新這些模塊,極大地加速了開發(fā)時間。

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ù)器域名與端口,可以換成本機ip

      'webpack/hot/only-dev-server',
      // 為熱替換(HMR)打包好代碼
      // only- 意味著只有成功更新運行代碼才會執(zhí)行熱替換(HMR)


      './index.js'
      // 我們 app 的入口文件
    ],
    vendor: ['react', 'react-router']
    // 公共文件打包
  }

出口配置 publicPath,(必須配置)

  output: {
    path: defPath.DEV_PATH,
    // 所有輸出文件的目標路徑

    filename: 'js/bundle.js',

    publicPath: '/',

    chunkFilename: '[name].chunk.js'
  },

plugins 添加相應(yīng)插件

  plugins: [
    new webpack.HotModuleReplacementPlugin(),
    // 開啟全局的模塊熱替換(HMR)

    new webpack.NamedModulesPlugin()
    // 控制臺輸出模塊命名美化
  ]

devServer 配置 HMR

  devServer: {
    // ... 其他配置

    hot: true,
    // 開啟服務(wù)器的模塊熱替換(HMR)

    contentBase: defPath.DEV_PATH,
    // 輸出文件的路徑

    publicPath: '/'
    // 和 output 的 publicPath 保持一致
  }

應(yīng)用代碼中修改

應(yīng)用代碼中需要做很大的改動

拆分原入口文件

新建一個根組件,存放原入口文件中的路由配置部分

  /*
    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)建一個增強版的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é)點
  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驗證的具體用法(Props Validation)

    React教程之Props驗證的具體用法(Props Validation)

    這篇文章主要介紹了React教程之Props驗證的具體用法(Props Validation),非常具有實用價值,需要的朋友可以參考下
    2017-09-09
  • React?Context用法小結(jié)(附完整代碼)

    React?Context用法小結(jié)(附完整代碼)

    這篇文章主要介紹了React?Context用法小結(jié)(附完整代碼),Context提供了一種新的組件之間共享數(shù)據(jù)的方式,允許數(shù)據(jù)隔代傳遞,而不必顯式的通過組件樹逐層傳遞props,本文通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-04-04
  • react PropTypes校驗傳遞的值操作示例

    react PropTypes校驗傳遞的值操作示例

    這篇文章主要介紹了react PropTypes校驗傳遞的值操作,結(jié)合實例形式分析了react PropTypes針對傳遞的值進行校驗操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2020-04-04
  • react實現(xiàn)列表滾動組件功能

    react實現(xiàn)列表滾動組件功能

    在開發(fā)項目的時候,從服務(wù)端獲取到數(shù)據(jù)列表后,展示給用戶看,需要實現(xiàn)數(shù)據(jù)自動滾動效果,怎么實現(xiàn)呢,下面小編給大家分享react實現(xiàn)列表滾動組件功能實現(xiàn)代碼,感興趣的朋友一起看看吧
    2023-09-09
  • React Hook之使用Effect Hook的方法

    React Hook之使用Effect Hook的方法

    這篇文章主要為大家詳細介紹了React 使用Effect Hook的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • React替換傳統(tǒng)拷貝方法的Immutable使用

    React替換傳統(tǒng)拷貝方法的Immutable使用

    Immutable.js出自Facebook,是最流行的不可變數(shù)據(jù)結(jié)構(gòu)的實現(xiàn)之一。它實現(xiàn)了完全的持久化數(shù)據(jù)結(jié)構(gòu),使用結(jié)構(gòu)共享。所有的更新操作都會返回新的值,但是在內(nèi)部結(jié)構(gòu)是共享的,來減少內(nèi)存占用
    2023-02-02
  • React的createElement和render手寫實現(xiàn)示例

    React的createElement和render手寫實現(xiàn)示例

    這篇文章主要為大家介紹了React的createElement和render手寫實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • react-native?父函數(shù)組件調(diào)用類子組件的方法(實例詳解)

    react-native?父函數(shù)組件調(diào)用類子組件的方法(實例詳解)

    這篇文章主要介紹了react-native?父函數(shù)組件調(diào)用類子組件的方法,通過詳細步驟介紹了React 函數(shù)式組件之父組件調(diào)用子組件的方法,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09
  • React Native 集成 ArcGIS 地圖的詳細過程

    React Native 集成 ArcGIS 地圖的詳細過程

    ArcGIS官方提供了 JavaScript SDK,也提供了 ArcGIS-Runtime-SDK-iOS,但是并沒有提供 React Native的版本,所以這里使用了 react-native-arcgis-mapview 庫,本文給大家介紹React Native 集成 ArcGIS 地圖的詳細過程,感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • 詳解React項目中eslint使用百度風格

    詳解React項目中eslint使用百度風格

    這篇文章主要介紹了React項目中eslint使用百度風格,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09

最新評論