一、Redux中间件原理
redux中间件的“中间”指的是action和store之间,在redux之中,action只能是一个对象被dispatch分发,当使用redux-thunk之后,action可以是一个函数了,由此可以,实际上中间件其实就是对dispatch方法的封装,或者说是对dispatch方法的升级。例如,在redux-thunk之后,当dispatch方法接收的参数为一个对象的时候会直接传给store,如果接收的是一个函数的时候,它就会让这个方法先执行。
二、redux-logger中间件
redux-logger会在dispatch改变仓库状态的时候打印出旧的仓库状态、当前触发的action以及新的仓库状态
// 简单实现let next = store.dispatchstore.dispatch = (action) => {console.log('prev state',store.getState())console.log('action',action)next(action)console.log('next state',store.getState())}
三、redux-thunk中间件
redux-thunk是一个比较流行的action异步中间件,使用场景:1.当需要在一个action中触发多个dispatch。2.需要在action中做其他任何函数能做的事情,比如带副作用的事情
function createThunkMiddleware(extraArgument) {return ({ dispatch, getState }) => next => action => {if (typeof action === 'function') {return action(dispatch, getState, extraArgument);}return next(action);};}const thunk = createThunkMiddleware();thunk.withExtraArgument = createThunkMiddleware;export default thunk;
简单来说就是,就是判断每个action:如果是function类型,就调用这个function(并传入 dispatch 和 getState 及 extraArgument 为参数),而不是任由让它到达 reducer,因为 reducer 是个纯函数,Redux 规定到达 reducer 的 action 必须是一个 plain object 类型。参数dispatch就是store.dispatch,参数getState 就是store.getState
