Why do we need middleware for async flow in Redux?

前端 未结 11 2239
忘了有多久
忘了有多久 2020-11-22 04:17

According to the docs, \"Without middleware, Redux store only supports synchronous data flow\". I don\'t understand why this is the case. Why can\'t the container component

11条回答
  •  失恋的感觉
    2020-11-22 04:48

    OK, let's start to see how middleware working first, that quite answer the question, this is the source code applyMiddleWare function in Redux:

    function applyMiddleware() {
      for (var _len = arguments.length, middlewares = Array(_len), _key = 0; _key < _len; _key++) {
        middlewares[_key] = arguments[_key];
      }
    
      return function (createStore) {
        return function (reducer, preloadedState, enhancer) {
          var store = createStore(reducer, preloadedState, enhancer);
          var _dispatch = store.dispatch;
          var chain = [];
    
          var middlewareAPI = {
            getState: store.getState,
            dispatch: function dispatch(action) {
              return _dispatch(action);
            }
          };
          chain = middlewares.map(function (middleware) {
            return middleware(middlewareAPI);
          });
          _dispatch = compose.apply(undefined, chain)(store.dispatch);
    
          return _extends({}, store, {
            dispatch: _dispatch
          });
        };
      };
    }
    

    Look at this part, see how our dispatch become a function.

      ...
      getState: store.getState,
      dispatch: function dispatch(action) {
      return _dispatch(action);
    }
    
    • Note that each middleware will be given the dispatch and getState functions as named arguments.

    OK, this is how Redux-thunk as one of the most used middlewares for Redux introduce itself:

    Redux Thunk middleware allows you to write action creators that return a function instead of an action. The thunk can be used to delay the dispatch of an action, or to dispatch only if a certain condition is met. The inner function receives the store methods dispatch and getState as parameters.

    So as you see, it will return a function instead an action, means you can wait and call it anytime you want as it's a function...

    So what the heck is thunk? That's how it's introduced in Wikipedia:

    In computer programming, a thunk is a subroutine used to inject an additional calculation into another subroutine. Thunks are primarily used to delay a calculation until it is needed, or to insert operations at the beginning or end of the other subroutine. They have a variety of other applications to compiler code generation and in modular programming.

    The term originated as a jocular derivative of "think".

    A thunk is a function that wraps an expression to delay its evaluation.

    //calculation of 1 + 2 is immediate 
    //x === 3 
    let x = 1 + 2;
    
    //calculation of 1 + 2 is delayed 
    //foo can be called later to perform the calculation 
    //foo is a thunk! 
    let foo = () => 1 + 2;
    

    So see how easy the concept is and how it can help you manage your async actions...

    That's something you can live without it, but remember in programming there are always better, neater and proper ways to do things...

提交回复
热议问题