We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
redux-thunk是redux的一个中间件, 实现对dispatch操作的异步实现, 然而其原码却极其精简:
redux-thunk
src/
index.js
因为只有十四行, 可以直接贴上来:
function createThunkMiddleware(extraArgument) { return ({ dispatch, getState }) => next => action => { if (typeof action === 'function') { return action(dispatch, getState, extraArgument); } return next(action); }; } const thunk = createThunkMiddleware(); thunk.withExtraArgument = createThunkMiddleware; export default thunk;
细数一下有3层函数注入, 生成最后实际接收action的函数. 这里可以认为:
先看最内层匿名函数的逻辑:
if (typeof action === 'function') { return action(dispatch, getState, extraArgument); } return next()
因为如果action属于函数类型, 那么认为该函数会进行异步操作, 进行异步操作意味着不会马上执行, 而每一次action都需要实际的dispatch操作, 所以将dispatch和getState作为参数的形式注入异步action对象, 让该函数获得访问store的能力和提出dispatch的能力, 希望其(该action函数)在将来执行实际的dispatch操作.
dispatch
getState
因为redux-thunk是作为redux的中间件的实体存在, 所以辅以redux源码如何应用中间的逻辑就能帮助我们完全弄懂以上的各个=>的所有意思, 这里可以先根据每一次的参数提前点出相关认识:
redux
=>
extraAugument, 对异步action函数注入额外的参数, 相当于一个全局(所有action函数的范畴)变量. 默认的最终redux-thunk模块对外暴露是抛弃该参数的: const thunk = createThunkMiddleware();.
extraAugument
const thunk = createThunkMiddleware();
({ dispatch, getState }), 注入访问store和发起dispath的能力
({ dispatch, getState })
store
dispath
next, 与其他中间件获得链式关联
next
action, 实际action实体, redux-thunk的任务就是对每一次传到本层的action进行校验, 判断其是否为函数, 如果符合, 则对该action进行dispatch和getStore的能力的赋予,并终止该action在中间件的传播
action
getStore
最后需要清楚地点出, 所有的redux中间件都满足这种形式: ({ dispatch, getState }) => next => action => { }的形式, 并不是redux-thunk的特立独行, 这是因为这种方式才能对应的上redux对中间件的处理.
({ dispatch, getState }) => next => action => { }
根据刚才从redux-thunk的格式分析(所有)中, 可以推测redux对中间件们作了以下的处理:
next(action)
根据这里要点的掌握就可以的redux的源码中寻找处理逻辑的相关根源了. 对开发者直接对中间件应用的认识毫无疑问是applyMiddleware函数, 应用形式为:
applyMiddleware
createStore(rootReducer, applyMiddleware(thunkMiddleware))
根据这个的感性认识, 翻看createStore的接口
export default function createStore(reducer, preloadedState, enhancer) { // 判断是否由preloadedState, 没有的话, enhancer获得preloadedState的值 // 将createStore传给enhancer, 这里可以直观认为是applymiddleware函数工厂生成的函数 return enhancer(createStore)(reducer, preloadedState) }
可以看出
enhancer(createStore)
返回一个增强性的createStore(装饰器模式), 然后进行实际调用, 这里的增强对applymiddleware来说就是修改dispatch函数. 查看调用applyMiddleware(...)的返回的接口签名:
applymiddleware
export default function applyMiddleware(...middlewares) { return createStore => (...args) => { const store = createStore(...args)
可以(...args)看出, applyMiddleware没有对createStore的参数手脚, 可以推出后续的API的修改
({ dispatch, getState })相关: 实现对每个中间件对store的访问能力和提出dispatch的能力
const middlewareAPI = { getState: store.getState, dispatch: (...args) => dispatch(...args) } chain = middlewares.map(middleware => middleware(middlewareAPI))
中间结果是chain, 此时满足所有中间件被拆解成: next => action => { }
next => action => { }
next相关: 实现所有中间件之间的链式关联
dispatch = compose(...chain)(store.dispatch)
这段代码有点绕, 先结论: store.dispatch是最后一层中间件, 如果前面的中间都没有处理本茨action的想法, 那么由原生的dispatch进行处理
函数工具compose的出现意味着中间件的使用形式是从右到左的, 所以applyMiddleware()的时候注意中间件的传入顺序. 这里值得推翘的是即使在compose(...chain)完中间件的形式还是next => action => { }, store.dispatch才是真正的导火线, 让所有中间件成为完全态 action => { }
compose
action => { }
The text was updated successfully, but these errors were encountered:
No branches or pull requests
Warning⚠️
前言
redux-thunk
是redux的一个中间件, 实现对dispatch操作的异步实现, 然而其原码却极其精简:src/
目录里面只有一个index.js
文件index.js
文件里面只有14行(v2.2.0)揭开redux-thunk的面纱
因为只有十四行, 可以直接贴上来:
细数一下有3层函数注入, 生成最后实际接收action的函数. 这里可以认为:
先看最内层匿名函数的逻辑:
因为如果action属于函数类型, 那么认为该函数会进行异步操作, 进行异步操作意味着不会马上执行, 而每一次action都需要实际的dispatch操作, 所以将
dispatch
和getState
作为参数的形式注入异步action对象, 让该函数获得访问store的能力和提出dispatch的能力, 希望其(该action函数)在将来执行实际的dispatch操作.因为
redux-thunk
是作为redux
的中间件的实体存在, 所以辅以redux源码如何应用中间的逻辑就能帮助我们完全弄懂以上的各个=>
的所有意思, 这里可以先根据每一次的参数提前点出相关认识:extraAugument
, 对异步action函数注入额外的参数, 相当于一个全局(所有action函数的范畴)变量. 默认的最终redux-thunk
模块对外暴露是抛弃该参数的:const thunk = createThunkMiddleware();
.({ dispatch, getState })
, 注入访问store
和发起dispath
的能力next
, 与其他中间件获得链式关联action
, 实际action
实体,redux-thunk
的任务就是对每一次传到本层的action
进行校验, 判断其是否为函数, 如果符合, 则对该action进行dispatch
和getStore
的能力的赋予,并终止该action
在中间件的传播最后需要清楚地点出, 所有的redux中间件都满足这种形式:
({ dispatch, getState }) => next => action => { }
的形式, 并不是redux-thunk
的特立独行, 这是因为这种方式才能对应的上redux对中间件的处理.redux中处理中间件的源码阅读
根据刚才从
redux-thunk
的格式分析(所有)中, 可以推测redux
对中间件们作了以下的处理:({ dispatch, getState })
层注入next
参数实现, 这样可以在最终每个中间件就可以对下一层的中间件负责, 决定是否调用next(action)
让后续中间件进行本次action的处理根据这里要点的掌握就可以的redux的源码中寻找处理逻辑的相关根源了. 对开发者直接对中间件应用的认识毫无疑问是
applyMiddleware
函数, 应用形式为:根据这个的感性认识, 翻看createStore的接口
可以看出
返回一个增强性的createStore(装饰器模式), 然后进行实际调用, 这里的增强对
applymiddleware
来说就是修改dispatch函数.查看调用applyMiddleware(...)的返回的接口签名:
可以(...args)看出, applyMiddleware没有对createStore的参数手脚, 可以推出后续的API的修改
({ dispatch, getState })
相关: 实现对每个中间件对store的访问能力和提出dispatch的能力中间结果是chain, 此时满足所有中间件被拆解成:
next => action => { }
next
相关: 实现所有中间件之间的链式关联这段代码有点绕, 先结论: store.dispatch是最后一层中间件, 如果前面的中间都没有处理本茨action的想法, 那么由原生的dispatch进行处理
函数工具
compose
的出现意味着中间件的使用形式是从右到左的, 所以applyMiddleware()的时候注意中间件的传入顺序.这里值得推翘的是即使在compose(...chain)完中间件的形式还是
next => action => { }
, store.dispatch才是真正的导火线, 让所有中间件成为完全态action => { }
Warning⚠️
前言
redux-thunk
是redux的一个中间件, 实现对dispatch操作的异步实现, 然而其原码却极其精简:src/
目录里面只有一个index.js
文件index.js
文件里面只有14行(v2.2.0)揭开redux-thunk的面纱
因为只有十四行, 可以直接贴上来:
细数一下有3层函数注入, 生成最后实际接收action的函数. 这里可以认为:
先看最内层匿名函数的逻辑:
因为如果action属于函数类型, 那么认为该函数会进行异步操作, 进行异步操作意味着不会马上执行, 而每一次action都需要实际的dispatch操作, 所以将
dispatch
和getState
作为参数的形式注入异步action对象, 让该函数获得访问store的能力和提出dispatch的能力, 希望其(该action函数)在将来执行实际的dispatch操作.因为
redux-thunk
是作为redux
的中间件的实体存在, 所以辅以redux源码如何应用中间的逻辑就能帮助我们完全弄懂以上的各个=>
的所有意思, 这里可以先根据每一次的参数提前点出相关认识:extraAugument
, 对异步action函数注入额外的参数, 相当于一个全局(所有action函数的范畴)变量. 默认的最终redux-thunk
模块对外暴露是抛弃该参数的:const thunk = createThunkMiddleware();
.({ dispatch, getState })
, 注入访问store
和发起dispath
的能力next
, 与其他中间件获得链式关联action
, 实际action
实体,redux-thunk
的任务就是对每一次传到本层的action
进行校验, 判断其是否为函数, 如果符合, 则对该action进行dispatch
和getStore
的能力的赋予,并终止该action
在中间件的传播最后需要清楚地点出, 所有的redux中间件都满足这种形式:
({ dispatch, getState }) => next => action => { }
的形式, 并不是redux-thunk
的特立独行, 这是因为这种方式才能对应的上redux对中间件的处理.redux中处理中间件的源码阅读
根据刚才从
redux-thunk
的格式分析(所有)中, 可以推测redux
对中间件们作了以下的处理:({ dispatch, getState })
层注入next
参数实现, 这样可以在最终每个中间件就可以对下一层的中间件负责, 决定是否调用next(action)
让后续中间件进行本次action的处理根据这里要点的掌握就可以的redux的源码中寻找处理逻辑的相关根源了. 对开发者直接对中间件应用的认识毫无疑问是
applyMiddleware
函数, 应用形式为:根据这个的感性认识, 翻看createStore的接口
可以看出
返回一个增强性的createStore(装饰器模式), 然后进行实际调用, 这里的增强对
applymiddleware
来说就是修改dispatch函数.查看调用applyMiddleware(...)的返回的接口签名:
可以(...args)看出, applyMiddleware没有对createStore的参数手脚, 可以推出后续的API的修改
({ dispatch, getState })
相关: 实现对每个中间件对store的访问能力和提出dispatch的能力中间结果是chain, 此时满足所有中间件被拆解成:
next => action => { }
next
相关: 实现所有中间件之间的链式关联这段代码有点绕, 先结论: store.dispatch是最后一层中间件, 如果前面的中间都没有处理本茨action的想法, 那么由原生的dispatch进行处理
函数工具
compose
的出现意味着中间件的使用形式是从右到左的, 所以applyMiddleware()的时候注意中间件的传入顺序.这里值得推翘的是即使在compose(...chain)完中间件的形式还是
next => action => { }
, store.dispatch才是真正的导火线, 让所有中间件成为完全态action => { }
The text was updated successfully, but these errors were encountered: