zoukankan      html  css  js  c++  java
  • Redux-devTools

     原文:https://www.jianshu.com/p/a2d4c1856560

    创建DevTools组件

    在你的App项目中,通过“Monitor(监视显示)”用createDevTools创建一个DevTools组件。示例用了最常用,最简单的LogMonitorDockMonitor

    import React from 'react'
    
    //从redux-devtools中引入createDevTools
    import { createDevTools } from 'redux-devtools';
    
    //显示包是单独的,要额外指定
    import LogMonitor from 'redux-devtools-log-monitor';
    import DockMonitor from 'redux-devtools-dock-monitor';
    
    //创建DevTools组件
    const DevTools = createDevTools(
      <DockMonitor toggleVisibilityKey='ctrl-h'
                   changePositionKey  ='ctrl-q'>
        <LogMonitor theme='tomorrow' />
      </DockMonitor>
    );
    
    export default DevTools
    
    

     

    DevTools.instrument()通过redux的compose来扩展store

    createDevTools() 创建的DevTools组件有个特殊的静态方法instrument(),它返回一个store的增强器,在开发中你需要在compose中使用。注意:DevTools.instrument()要放在applyMiddleware后,因为applyMinddleare可能存在异步行为,为了确保所有额actions显示在store中,所以要放在后面。

    store/create.js

    import {createStore,applyMiddleware,compose} from 'redux'
    import rootReducer from './modules/reducers'
    
    import thunk from './middleware/thunk'
    import DevTools from '../containers/DevTools'
    
    const enhancer = compose(
      //你要使用的中间件,放在前面
      applyMiddleware(thunk),
      //必须的!启用带有monitors(监视显示)的DevTools
      DevTools.instrument()
    )
    
    export default function createStoreWithMiddleware(initialState){
      //注意:仅仅只有redux>=3.1.0支持第三个参数
      const store = createStore(rootReducer,initialState,enhancer)
      return store
    }
    

      

    Render <DevTools /> in your App

    import React from 'react';
    import { render } from 'react-dom';
    import { Provider } from 'react-redux';
    import configureStore from './store/configureStore';
    import TodoApp from './components/Counter';
    
    //注意,不要直接这样做,要区分开发环境和生产环境
    import DevTools from './containers/DevTools';
    
    const store = configureStore();
    
    render(
      <Provider store={store}>
        <div>
          <Counter />
          <DevTools />
        </div>
      </Provider>
      document.getElementById('app')
    );
    

      

     

    111111
  • 相关阅读:
    学习使用&运算符
    企业发放的奖金根据利润提成。
    取一个整数a从右端开始的47位。
    jQuery Select操作大集合
    js 获取某年某月的最后一天
    sql 语句区分大小写查询
    js 冒泡排序
    一个初学者的程序自学计划
    JWNL体验
    (转)GIS相关的SCI、EI期刊
  • 原文地址:https://www.cnblogs.com/whl4835349/p/11058834.html
Copyright © 2011-2022 走看看