个人总结:

讲一下bindActionCreators这个API,

bindActionCreators是要结合mapDispatchToProps来使用的。

mapDispatchToProps函数接收一个函数,这个函数返回一个对象,对象中键是action的名字,值是进行dispatch处理的函数

例:

mapDispatchToProps((dispatch)=>{

  return {

    action:(data) => dispatch( { type:'add',payload:data } )

          /*

通常情况下都用actioncreator来生成action,所以通常是下面的写法:

action:(data) => dispatch( actioncreator(data) )

               */

}

})

由于通常的写法下action都是由actioncreator来生成的,既然所有的都有这样的操作,不如弄个函数来封装一下

于是就有了bindActionCreators,写法变成了这样:

mapDispatchToProps =((dispatch)=>{

return {

     action:bindActionCreators({

action1:actionCreator1,

          action2:actionCreator2  //这样写的花就不涉及dispatch等操作的明文编写了

})

}

}

进行了mapDispatchToProps操作之后,就可以在props中调用方法了

this.props.action1()

this.props.action2()

就可以直接使用这些方法了。

==========================================================================================================================

原文转载自网络:

问题描述

  • 使用react-redux时使用connect方法将store和组件关联在一起,那么connect的第二个参数是mapDispatchToProps
  • 在mapDispatchToProps中,第一个参数是dispatch,函数的返回值是一个对象,并且对象中的每一个值都是一个函数,函数都可以通过this.props.key调用。
  • 问题"

    • 为什么redux官网上推荐了bindActionCreators,这个有什么作用呢?
    • 使用不同的方式写mapDispatchToProps对action工厂函数的要求有什么不同吗
    • 如果是异步action该如何使用bindActionCreators呢

问题解决

A1:和以前的写法对比:

  • 对于dispatch一个同步action,mapDispatchToProps以前写法

    connect((state)=> ({order: state.order})),
    (dispatch) => ({
    getOrder: (data) => dispatch(actionCreator(data))
    }))
    • mapDispatchToProps函数被调用的时候会传入dispatch这个参数,返回的对象中每个函数中都可以使用这个dispatch去发送一个action对象(注意我们通常使用action的工厂函数action creator构造action对象)因此返回的每一个函数中都会有这样类似操作。那么就可以写一个bindActionCreators将dispacth函数和action构造函数直接结合在一起就可以了。 因此可以换一种写法
  • connect((state)=> ({order: state.order})),
    (dispatch) => ({
    actions: bindActionCreators({
    action1: actionCreator1,
    action2: actionCreator2
    }),dispatch)
    //等价于
    connect((state)=> ({order: state.order})),
    (dispatch) => ({
    actions: {
    action1: () => dispacth(actionCreator1()),
    action2: () => dispacth(actionCreator2())
    }}))
  • 对于异步action

    • 同样可以使用bindActionCreators
    • 只要你的action构造函数返回值是一个函数
    • 这时候bindActionCreators 会使用dispatch将这个函数发送出去
    • 当然reducer不能接受
    • 就会被交给中间件redux-thunk处理,这时候返回的函数会在异步操作结束之后被调用并传入dispatch作为参数
  • 因此bindActionCreators可以直接dispacth第一个参数(对象)的返回值

  • Q2:使用bindActionCreators好处是什么呢?

  • A2:实际上就是将dispatch直接和action creator结合好然后发出去的这一部分操作给封装成一个函数

  • Q3:那么使用bindActionCreators如何调用不同的dispacth方法呢?

  • A3: 如下代码使用this.props.actions是一个对象,其中的每一个item的key就是action creator的function的名字,value就是加了dispatch这个action的function

    connect((state)=> ({order: state.order})),
(dispatch) => ({
actions: bindActionCreators({
action1: actionCreator1,
action2: actionCreator2
}),dispatch)
//this.props.actions.action1()

bindActionCreators作用的更多相关文章

  1. bindActionCreators

    在 http://www.ruanyifeng.com/blog/2016/09/redux_tutorial_part_three_react-redux.html 没有介绍这个,react-red ...

  2. redux的bindActionCreators

    bindActionCreators是redux的一个API,作用是将单个或多个ActionCreator转化为dispatch(action)的函数集合形式. 开发者不用再手动dispatch(ac ...

  3. if __name__== "__main__" 的意思(作用)python代码复用

    if __name__== "__main__" 的意思(作用)python代码复用 转自:大步's Blog  http://www.dabu.info/if-__-name__ ...

  4. (转载)linux下各个文件夹的作用

    linux下的文件结构,看看每个文件夹都是干吗用的/bin 二进制可执行命令 /dev 设备特殊文件 /etc 系统管理和配置文件 /etc/rc.d 启动的配置文件和脚本 /home 用户主目录的基 ...

  5. github中的watch、star、fork的作用

    [转自:http://www.jianshu.com/p/6c366b53ea41] 在每个 github 项目的右上角,都有三个按钮,分别是 watch.star.fork,但是有些刚开始使用 gi ...

  6. web.xml中welcome-file-list的作用

    今天尝试使用struts2+ urlrewrite+sitemesh部署项目,结果发现welcome-file-list中定义的欢迎页不起作用: <welcome-file-list> & ...

  7. web.xml中load-on-startup的作用

    如下一段配置,熟悉DWR的再熟悉不过了:<servlet>   <servlet-name>dwr-invoker</servlet-name>   <ser ...

  8. SQLSERVER中NULL位图的作用

    SQLSERVER中NULL位图的作用 首先感谢宋沄剑提供的文章和sqlskill网站:www.sqlskills.com,看下面文章之前请先看一下下面两篇文章 SQL Server误区30日谈-Da ...

  9. 电容与EMC-电容不同功能时对整板EMC的作用

    一般我们的pcb板的器件有很多种类,但是值得特别关注的,很多人都会说是BGA.接口.IC.晶振之类,因为这些都是layout功能模块以及设计难点.然而数量上占绝对优势的器件却是阻容器件,之前围殴阻抗时 ...

随机推荐

  1. linux 结构需要清理 (structure needs cleaning)

    下面操作会删除挂载点所有文件,注意备份. df -T 查看出错的挂载点对应的文件系统和文件系统类型   然后umount这个文件系统 umount /dev/sda1 然后文件系统类型不同操作不同  ...

  2. 序列模型(4)----门控循环单元(GRU)

    一.GRU 其中, rt表示重置门,zt表示更新门. 重置门决定是否将之前的状态忘记.(作用相当于合并了 LSTM 中的遗忘门和传入门) 当rt趋于0的时候,前一个时刻的状态信息ht−1会被忘掉,隐藏 ...

  3. [luogu4053 JSOI2007] 建筑抢修 (贪心 优先队列)

    传送门 题目描述 小刚在玩JSOI提供的一个称之为"建筑抢修"的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者.但是T部落的基地里已经有N个建筑设施受到了严重的损伤 ...

  4. locate-updatedb命令检索不全

    locate-updatedb命令检索不全 执行updatedb命令,用于立刻更新locate命令所必需的数据库文件,但有些文件可能会在检索过程中被过滤掉. 有时候明明存在的文件,用find命令都能搜 ...

  5. 第n个质数

    //注:for循环之后第三个式子总会操作一遍. #include <iostream> using namespace std; int main() { int n; while (ci ...

  6. properties 乱码问题

    File --> Others Settings --> Default Settings

  7. POI 海量数据

    http://blog.csdn.net/Little_Stars/article/details/8266262

  8. Java n个线程轮流打印数字的问题

    一. 实现两个线程.轮流打印出数字.例如以下: bThread --> 10 aThread --> 9 bThread --> 8 aThread --> 7 bThread ...

  9. 根据BDUSS获取用户ID信息

    代码在 /data/svndir/business/workroot2/app/ecom/ubec/getuser

  10. POJ 1811

    使用Pollard_rho算法就可以过了 #include <iostream> #include <cstdio> #include <algorithm> #i ...