javascript - mapDispatchToProps 与 store.dispatch()

标签 javascript reactjs redux react-redux

是在组件内部使用 mapDispatchToProps 来调用 Action 更有效,还是在 Action 创建器中使用 store.dispatch 更有效?

mapDispatchToProps 示例:

// Component

import React from 'React';
import { connect } from 'react-redux';
import { defaultAction } from './actions';

class MyComponent extends Component {
  onClickHandler() {
    this.props.dispatch(defaultAction());
  }

  render() {
    return (<div onClick={this.onClickHandler.bind(this)} />);
  }
}

function mapDispatchToProps(dispatch) {
  return { dispatch };
}

export default connect(mapDispatchToProps)(MyComponent);



// Actions

import { DEFAULT_ACTION } from './constants';

export function defaultAction() {
  return {
    type: DEFAULT_ACTION,
  };
}

store.dispatch() 示例:

// Component

import React from 'React';
import { connect } from 'react-redux';
import { defaultAction } from './actions';

class MyComponent extends Component {
  onClickHandler() {
    defaultAction();
  }

  render() {
    return (<div onClick={this.onClickHandler.bind(this)} />);
  }
}

export default MyComponent;


// Actions

import { DEFAULT_ACTION } from './constants';
import store from './store';

export function defaultAction() {
  store.dispatch({
    type: DEFAULT_ACTION,
  });
}

我的猜测是,使用 mapDispatchToProps 而不是导入整个 ./store 来调度操作会更有效。

最佳答案

通常建议使用通过 mapDispatchToProps 提供给您的 dispatch,而不是将您的 action creator 方法耦合到您的商店单例。 Here's some in depth discussion about it.

关于javascript - mapDispatchToProps 与 store.dispatch(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41107067/

相关文章:

javascript - React 函数没有在 render() 中被回调

javascript - 如何增加 Vis.js 网络图节点中的标签填充?

javascript - 使用 setInterval() 刷新图像

javascript - 在指定的BPM中录制音频

javascript - 如何从 Jest 测试套件中排除 CSS 模块文件?

reactjs - React-Redux - Hooks API

javascript - 如何在不导出整个类的情况下导出静态类方法

reactjs - React 中的 IF ELSE(如果条件正确,带我到另一个页面)

reactjs - 在 react 表上动态设置页数

javascript - 如何在 TypeScript 中实现静态类型的不可变 redux 状态树?