继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

React总结篇之九_扩展Redux

holdtom
关注TA
已关注
手记 1703
粉丝 240
获赞 991


中间件

Store Enhancer

一、中间件

中间件的特点是:

中间件是独立的函数

中间件可以组合使用

中间件有一个统计的接口

中间件接口

在Redux框架中,中间件处理的是action对象,而派发action对象的就是Store上的dispatch函数,action对象在进入reducer之前,会经历中间件的管道。在这个中间件管道中,每个中间件都会接收到action对象,在处理完毕之后,就会把action对象交给下一个中间件来处理,只有所有的中间件都处理完action对象之后,才轮到reducer来处理action对象,但是如果某个中间件觉得没有必要继续处理这个action对象了,就不会把action对象交给下一个中间件,对这个action对象的处理就此为止,也就轮不到reducer上场了。

以action为参数的函数对传入的action对象进行处理,因为JavaScript支持闭包,在这个函数里可以访问上面两层函数的参数,所以可以根据需要做很多事情,包括以下功能:

调用dispatch派发出一个新的action对象;

调用getState获得当前Redux Store上的状态;

调用next告诉Redux当前中间件工作完毕,让Redux调用下一个中间件;

访问action对象action上的所有数据;

具有上面这些功能,一个中间件足够获取Store上的所有信息,也具有足够能力控制数据的流转。

使用中间件

使用中间件有两种方法,两种方法都离不开Redux提供的applyMiddleware函数。

(1)用Redux提供的applyMiddleware来包装createStore产生一个新的创建Store的函数,以使用redux-chunk中间件为例,代码如下:

React总结篇之九_扩展Redux

(2)把applyMiddleware的结果当做Store Enhancer,和其他Enhancer混合之后作为createStore参数传入。以同时使用redux-thunk和Redux Devtools增强器为例,代码如下:

React总结篇之九_扩展Redux

Promise中间件

实现异步action对象还有一个方法是利用promise,promise更加适用于输入输出操作,而且fetch函数返回的结果就是一个promise对象。对比redux-chunk和promise可以发现,如果应用redux-chunk,实际发起异步操作的语句是在中间件中调用的,而如果应用promise中间件,异步操作是在中间件之外引发的,因为只有异步操作发生了才会有promise对象,而promise中间件只是处理这个对象而已。

中间件开发原则

开发一个redux中间件,首先明确中间件的目的,因为中间件可以组合使用,所以不要让一个中间件的内容太过臃肿,尽量让一个中间件只完成一个功能,通过中间件的组合来完成丰富的功能。

二、Store Enhancer

中间件可以用来增强Redux store的dispatch方法,但也仅限于dispatch方法,也就是从dispatch函数调用到action对象被reducer处理的这个过程中的操作,如果想要对redux store进行更深层次的增强定制,就需要使用Store Enhancer。

增强器的接口

增强实例reset

reactreduxReact


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP