在组件内部使用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来分派(dispatch)操作会更有效。

最佳答案

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

10-06 05:10