微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

redux-thunk logger applyMiddleware

1 依赖:applyMiddleware源码

export default function applyMiddleware() {
  for (var _len = arguments.length,middlewares = Array(_len),_key = 0; _key < _len; _key++) {
    middlewares[_key] = arguments[_key];
  }

  return function (createStore) {
    //enhancer(createStore)(reducer,preloadedState);这里的enhancer就是applyMiddleware(thunk,logger)
    //enhancer(createStore)返回值就是下面这个函数;
    return function (reducer,preloadedState,enhancer) {
      //还是先创建一个store;
      var store = createStore(reducer,enhancer);
      //下面对创建的store中的dispatch进行改造;
      var _dispatch = store.dispatch;
      var chain = [];

      var middlewareAPI = {
        getState: store.getState,dispatch: function dispatch(action) {
          return _dispatch(action);
        }
      };
      //放入到chain数组中的函数都形成了闭包;
      chain = middlewares.map(function (middleware) {
        //在这里对thunk和logger
        return middleware(middlewareAPI);
      });
      //将_dispatch指向新的函数;传入的store.dispatch还是原始的dispatch;
      _dispatch = compose.apply(undefined,chain)(store.dispatch);
      //_dispatch = chain[0](chain[1](store.dispatch));
      //chain[1](store.dispatch) 返回值是一个函数,该返回值作为chain[0]的参数;
      //chain[0](chain[1](store.dispatch)) 的返回值是在下面源码处有注释
//返回最后的store
      return _extends({},store,{
        dispatch: _dispatch
      });
    };
  };
}

2 redux-thunk源码

'use strict';

exports.__esModule = true;
function createThunkMiddleware(extraArgument) {
  //下面返回函数其实就是thunk;
  return function (_ref) {
    //_ref就是middleWareAPI
    var dispatch = _ref.dispatch,getState = _ref.getState;
    //下面就是middleware(middlewareAPI);的返回值,被放到chain数组中,chain[0],形成闭包;
    return function (next) { //这里的next就是chain[1](store.dispatch);
      return function (action) {  //这里就是 chain[0](chain[1](store.dispatch)) 也就是最终的dispatch,所以最终可以dispatch(action);
        if (typeof action === 'function') {
          return action(dispatch,getState,extraArgument);
        }
        //如果action不是函数,那么就执行next,就是chain[1](store);
        return next(action);
      };
    };
  };
}

var thunk = createThunkMiddleware();
thunk.withExtraArgument = createThunkMiddleware;

exports['default'] = thunk;

什么是thunk

// Meet thunks.
// A thunk is a function that returns a function.
// This is a thunk.

3 Redux-logger源码

function createLogger() {
 //......删除了一些判断代码;
  return function (_ref) {
   // _ref就是middleWareAPI
    var getState = _ref.getState;
    //chain[1]其实就是这个函数;形成闭包;
    return function (next) {
      //chain[1](store.dispatch)就是下面这个函数;
      return function (action) {
        console.log('dispatch 前:',middlewareAPI.getState());
        var returnedValue = next(action);
        console.log('dispatch 后:',middlewareAPI.getState(),'\n');
        return returnedValue;
      };
    };
  };
}
//这里的{dispatch,getState}其实就是applyMiddleware中的
/*
      var middlewareAPI = {
        getState: store.getState,dispatch: function dispatch(action) {
          return _dispatch(action);
        }
      };
*/
//下面返回函数其实就是logger;
const defaultLogger = ({ dispatch,getState } = {}) => {
  if (typeof dispatch === 'function' || typeof getState === 'function') {
    //下面就是middleware(middlewareAPI);的返回值,被放到chain数组中,chain[1]
    return createLogger()({ dispatch,getState });
  }
}
export {defaultLogger as logger}

上面两者被放到chain数组中的函数其实都是类似于这样的

return function (next) {
      return function (action) {
      };
    };

4 logger最简化代码

function logger(middlewareAPI) {
  return function (next) {
    return function (action) {
      console.log('dispatch 前:',middlewareAPI.getState());
      var returnValue = next(action);
      console.log('dispatch 后:','\n');
      return returnValue;
    };
  };
}

5 结合applyMiddleware改进dispatch;

//createStore源码中有这么一行代码
enhancer(createStore)(reducer,logger)
//============
const store = createStore(
    reducer,applyMiddleware(thunk,logger)
);

redux-thunk

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


react 中的高阶组件主要是对于 hooks 之前的类组件来说的,如果组件之中有复用的代码,需要重新创建一个父类,父类中存储公共代码,返回子类,同时把公用属性...
我们上一节了解了组件的更新机制,但是只是停留在表层上,例如我们的 setState 函数式同步执行的,我们的事件处理直接绑定在了 dom 元素上,这些都跟 re...
我们上一节了解了 react 的虚拟 dom 的格式,如何把虚拟 dom 转为真实 dom 进行挂载。其实函数是组件和类组件也是在这个基础上包裹了一层,一个是调...
react 本身提供了克隆组件的方法,但是平时开发中可能很少使用,可能是不了解。我公司的项目就没有使用,但是在很多三方库中都有使用。本小节我们来学习下如果使用该...
mobx 是一个简单可扩展的状态管理库,中文官网链接。小编在接触 react 就一直使用 mobx 库,上手简单不复杂。
我们在平常的开发中不可避免的会有很多列表渲染逻辑,在 pc 端可以使用分页进行渲染数限制,在移动端可以使用下拉加载更多。但是对于大量的列表渲染,特别像有实时数据...
本小节开始前,我们先答复下一个同学的问题。上一小节发布后,有小伙伴后台来信问到:‘小编你只讲了类组件中怎么使用 ref,那在函数式组件中怎么使用呢?’。确实我们...
上一小节我们了解了固定高度的滚动列表实现,因为是固定高度所以容器总高度和每个元素的 size、offset 很容易得到,这种场景也适合我们常见的大部分场景,例如...
上一小节我们处理了 setState 的批量更新机制,但是我们有两个遗漏点,一个是源码中的 setState 可以传入函数,同时 setState 可以传入第二...
我们知道 react 进行页面渲染或者刷新的时候,会从根节点到子节点全部执行一遍,即使子组件中没有状态的改变,也会执行。这就造成了性能不必要的浪费。之前我们了解...