Redux 是 JavaScript 应用程序的状态管理库,以支持同步数据流而闻名。然而,要处理异步请求,需要使用 Redux Thunk 或 Redux Promise 等中间件。
默认情况下,Redux 运行在同步数据流模型上,这意味着它期望动作创建者返回描述状态更改的对象。这确保了状态更新的一致性和可预测性。然而,当执行异步操作时,例如从服务器获取数据,立即返回结果变得不切实际。
为了方便 Redux 中的异步操作,引入了中间件。中间件拦截分派到存储的操作,并能够处理副作用,例如发出 HTTP 请求或执行可能需要时间的计算。通过使用中间件,操作创建者可以启动异步操作,然后将结果作为操作分派。
中间件在异步管理 Redux 状态方面提供了多个好处:
考虑一个使用 AsyncApi 类模拟异步字段更新的简单 Redux 应用程序:
const App = (props) => { const update = () => { dispatch({ type: 'STARTED_UPDATING', }); AsyncApi.getFieldValue() .then((result) => dispatch({ type: 'UPDATED', payload: result, })); }; // ... };
虽然这种方法在技术上可行,但它通过异步处理使组件逻辑变得混乱,从而减少了
使用 Redux Thunk 或 Redux Promise 中间件,可以简化相同的代码:
const App = (props) => { const update = () => { dispatch(loadData(props.userId)); }; // ... }; const loadData = (userId) => (dispatch) => { fetch(`http://data.com/${userId}`) .then((res) => res.json()) .then( (data) => dispatch({ type: 'UPDATED', payload: data }), (err) => dispatch({ type: 'FAILURE', payload: err }), ); };
通过将异步逻辑分离到操作创建者中,该组件仍然不知道该操作的异步性质。它只是调度操作,中间件处理其余的事情。
虽然技术上可行,但不建议在 Redux 中不使用中间件处理异步操作。它引入了复杂性和维护开销。中间件提供了一种标准化的方法来管理副作用,使 Redux 应用程序中的异步数据流高效、方便且可测试。
以上是为什么在 Redux 中使用中间件进行异步操作?的详细内容。更多信息请关注PHP中文网其他相关文章!