到底什么是Redux中间件

它可以帮助我们在action里面去写函数,既然是中间件,肯定就是谁和谁的中间
在这里插入图片描述
view在redux中会派发一个action,action通过store的dispatch方法派发给store,store接收到action连同之前老的state一起传给reducer,reducer返回新的数据给store,store去改变自己的state,这是redux的流程。redux中间件的中间指的是action和store之间,之前在redux中action只能返回的一个对象,所以action是返回一个对象直接派发给了store,现在当我们使用redux-thunk之后action返回可以是函数了,action通过dispatch方法被传递给store,那么action和store之间就是dispatch这个方法,实际上中间件就是对dispatch方法的一个封装或者说对dispatch方法的一个升级,最原始的dispatch方法接收到一个对象之后会把这个对象传递给store,当把dispatch做了升级之后,比如说使用了redux-thunk 这个中间件,这个时候当调用dispatch方法给dispatch方法传递的参数是一个对象的话,那么dispatch就会把这个对象直接传递给store,跟之前我们写dispatch传递给它一个对象没什么区别,但是如果传递给dispatch方法是一个函数的话,这个时候dispatch已经升级了,它就不会把这个函数直接传递给store,它会先让你这个函数执行,执行完了之后需要调用store的时候再去调用store。所以dispatch在这里会根据参数的不同执行不同的事情。所以redux的中间件就是对store的dispatch做了个升级,升级之后dispatch就可以对象和函数都可以接收了。当然中间件不止redux-thunk 这一个,实际上redux的中间件很多,比如redux-logger,redux-saga。redux-saga也是解决redux中异步问题的中间件,redux-thunk是把异步操作放在action里操作,而redux-saga的设计思想是把异步操作单独拆分出来放在一个文件里管理。

猜你喜欢

转载自blog.csdn.net/u013565133/article/details/88816267