参考:http://www.ruanyifeng.com/blog/2016/09/redux_tutorial_part_two_async_operations.html
store.dispatch
方法进行了改造,在发出 Action 和执行 Reducer 这两步之间,添加了其他功能,使得能 Reducer 在异步操作结束后自动执行。import { applyMiddleware, createStore } from ‘redux‘; import createLogger from ‘redux-logger‘; const logger = createLogger(); const store = createStore( reducer, applyMiddleware(logger) );
上面代码中,redux-logger
提供一个生成器createLogger
,可以生成日志中间件logger
。然后,将它放在applyMiddleware
方法之中,传入createStore
方法,就完成了store.dispatch()
的功能增强。
store.dispatch
方法正常情况下,参数只能是对象,不能是函数。import { createStore, applyMiddleware } from ‘redux‘; import thunk from ‘redux-thunk‘; import reducer from ‘./reducers‘; // Note: this API requires redux@>=3.1.0 const store = createStore( reducer, applyMiddleware(thunk) );
上面代码使用redux-thunk
中间件,改造store.dispatch
,使得后者可以接受函数作为参数。
因此,异步操作的第一种解决方案就是,写出一个返回函数的 Action Creator,然后使用redux-thunk
中间件改造store.dispatch
。
import { createStore, applyMiddleware } from ‘redux‘; import promiseMiddleware from ‘redux-promise‘; import reducer from ‘./reducers‘; const store = createStore( reducer, applyMiddleware(promiseMiddleware) );
这个中间件使得store.dispatch
方法可以接受 Promise 对象作为参数。
export default function applyMiddleware(...middlewares) { return (createStore) => (reducer, preloadedState, enhancer) => { var store = createStore(reducer, preloadedState, enhancer); var dispatch = store.dispatch; var chain = []; var middlewareAPI = { getState: store.getState, dispatch: (action) => dispatch(action) }; chain = middlewares.map(middleware => middleware(middlewareAPI)); dispatch = compose(...chain)(store.dispatch); return {...store, dispatch} } }
原文:https://www.cnblogs.com/dadouF4/p/10535980.html