首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mapDispatchToProps与store.dispatch()

mapDispatchToProps与store.dispatch()
EN

Stack Overflow用户
提问于 2016-12-12 18:18:58
回答 1查看 4K关注 0票数 7

在组件中使用mapDispatchToProps来调用操作更有效,还是在操作创建者中使用store.dispatch更有效?

mapDispatchToProps 示例:

代码语言:javascript
复制
// 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() 示例:

代码语言:javascript
复制
// 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来调度操作更有效。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-12 18:53:54

通常建议使用通过dispatch提供给您的mapDispatchToProps,而不是将操作创建者方法耦合到存储单例。这里有一些深入的讨论。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41107067

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档