• 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
  • 相关阅读:
    接口默认值引发Qt调用DLL异常
    360杀毒引发的DLL调用异常
    VS2012基于QT5.1自定接口及插件并实现动态加载
    Qt调用C的DLL
    Qt动态多语言的实现(VS2012开发)
    Qt在VS2012中引用QtWidgets时报GLES2/gl2.h无法打开错误的解决办法
    php判断某字符串是否不以数字或其他特殊字符开头
    mysql的数据类型int、bigint、smallint 和 tinyint取值范围
    28个jQuery性能优化的建议
    主题:iframe高度的自适应
  • 原文地址:https://www.cnblogs.com/whl4835349/p/11058834.html
Copyright © 2020-2023  润新知