章节 8 - dispatch async action 2
优质
小牛编辑
131浏览
2023-12-01
运行之前我们在 dispatch-async-action-1.js 中实现的第一个异步 action creator:
import { createStore, combineReducers } from 'redux' var reducer = combineReducers({ speaker: function (state = {}, action) { console.log('speaker was called with state', state, 'and action', action) switch (action.type) { case 'SAY': return { ...state, message: action.message } default: return state; } } }) var store_0 = createStore(reducer) var asyncSayActionCreator_1 = function (message) { return function (dispatch) { setTimeout(function () { dispatch({ type: 'SAY', message }) }, 2000) } } console.log("\n", 'Running our async action creator:', "\n") store_0.dispatch(asyncSayActionCreator_1('Hi'))
// 输出: // ... // /Users/classtar/Codes/redux-tutorial/node_modules/redux/node_modules/invariant/invariant.js:51 // throw error; // ^ // Error: Invariant Violation: Actions must be plain objects. Use custom middleware for async actions. // ...
我们所设计的 function 似乎没有进入 reducer 函数。但是 Redux 给出了温馨提示:使用自定义中间件(middleware)来支持异步 action。
看来我们的方向是正确的,可中间件(middleware)又是什么呢?
我向你保证 action creator asyncSayActionCreator_1 不仅没有问题,而且只要我们搞清楚 middleware 的概念并掌握它的使用方法,这个异步 action creator 就会按照我们所设想的结果执行。