*rajaraodv * 原文请参看.
如果你使用过类似Express.js框架构建Node.js程序,你就可能在使用中间件,并且知道他们怎么工作.Redux给前端引入同样的概念.
什么是中间件?
中间件是可以被框架自动调用的函数,在框架中数据流结束之前,在数据流中加强或者改变输出.
例如:如果框架里面没有中间件是这个样子的:
funcA — calls→ funcB — calls→ funcC
添加了中间件以后,控制流就变为:
funcA — calls→ funcB — calls→ funcMiddleWare1 — back to →funcB. funcB → then calls→ funcMiddleWare2 — back to→ funcB. funcB — finally calls→ funcC
注意:funcB最终调用funcC但是在调用funcC之前要调用两个中间件.
没有中间件的Redux生命周期
让我们想看看Redux app生命周期,来更好的理解它.
场景:点击”Click Me”按钮,更新”Clicked xyz times” 文本.
图片1
场景:现在,当用户点击按钮的时候,我们想把点击的数目保存到服务器,并且在debugg中展示state的变化日志.让我们看看现在的控制流.
图片2
在Redux中,中间件函数一个接一个的被调用,直到所有的中间件被调用,然后“Action”对象呗发送到“Reducer”.
注意:这就允许中间件有修改Action对象的潜力,在最终调用Reducers之前,解析AJAX调用,还可以做其他事情比如日志.Reeucers将会更新state,在app需要的时候渲染组件.
使用中间件
Redux有个巨大的社区,已经构建了大量可以完成各种任务的中间件.
所有你需要做的就是:
- 通过npm 安装
- 配置或者添加到Redux
例如:在我前面的blog:创建React Redux CRUD程序指南,app为CRUD操作做AJAX请求.
在里面,我使用AXios的库来做AJAX调用.但是Axios返回一个Promise对象.但是Actions需要传递给Reducers的是一个纯粹的JSON对象.所以在在数据到达Reducers之前使用redux-promise解析Action中的Promise对象.
为了使用,首先安装.
npm install — save redux-promise
再做一点配置工作:
import React from ‘react’;
...
import { createStore, applyMiddleware } from ‘redux’;
import rp from ‘redux-promise’; // <------------ MIDDLEWARE
...
//add middlewares
const createStoreWithMiddleware = applyMiddleware(rp)(createStore);
ReactDOM.render(
, document.getElementById(‘body’));
中间件是怎么工作的?
如果你看了redux-promise,你就可以看到他是怎么工作的.
这里是伪代码:
- Redux调用中间件,“dispatch(函数)”,“next(函数)”和”action“JSON对象.
- 中间件检查”action”对象,看看是否有Promise对象
- 如果没有Promise对象,调用”next“函数返回到Redux.
- 如果这样做,他会附加上成功或者失败的回调函数,等待服务器的响应.
//redux-promise middleware source code
import { isFSA } from 'flux-standard-action';
function isPromise(val) {
return val && typeof val.then === 'function';
}
export default function promiseMiddleware({ dispatch }) {
return next => action => {
if (!isFSA(action)) {
return isPromise(action)
? action.then(dispatch)
: next(action);
}
return isPromise(action.payload)
? action.payload.then(
result => dispatch({ ...action, payload: result }),
error => dispatch({ ...action, payload: error, error: true })
)
: next(action);
};
}
更多内容请看:
- 官方Redux 中间件文档
- 中间件列表
- 到A Guide For Building A React Redux CRUD APP.
就这些内容了.