Redux 中间件是怎么拿到store 和 action? 然后怎么处理?

Redux 中间件的设计是基于高阶函数和链式调用的概念。中间件的基本形式是一个函数,这个函数返回另一个函数,这个返回的函数再返回一个函数,这样形成了一个闭包。

这里先看一下标准的Redux中间件的基本形式:

const middleware = store => next => action => {
  // 在这里处理你的代码
}
  • store:Redux的store实例,你可以调用store.getState()获取当前的state,或者store.dispatch()派发一个新的action。

  • next:这是一个函数,你可以调用next(action)来把控制权交给下一个中间件,如果没有下一个中间件,那么控制权就交给Redux。

  • action:这是当前派发的action。

中间件的处理流程通常是这样的:

  1. 中间件拿到当前的actionstore
  2. 根据需要,中间件可以在action被传递到reducer之前,修改action,拦截action,或者在action被处理后做一些额外的操作。
  3. 中间件处理完后,通过next(action)action传递给下一个中间件,如果没有下一个中间件,那么action将被传递给reducer。

例如,一个简单的中间件,用于在console里记录每个action和state的变化:

const logger = store => next => action => {
  console.log('dispatching', action)
  let result = next(action)
  console.log('next state', store.getState())
  return result
}

在这个例子中,每当一个action被派发,我们都会在console里记录这个action,然后调用next(action)将action传递给下一个中间件或者reducer,然后再记录新的state。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值