<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • 理解 redux-thunk 源碼

          2020-6-5    seo達人

          前言

          前面幾篇我們就 Redux 展開了幾篇文章,這次我們來實現 react-thunk,就不是叫實現 redux-thunk 了,直接上源碼,因為源碼就11行。如果對 Redux 中間件還不理解的,可以看我寫的 Redux 文章。


          實現一個迷你Redux(基礎版)

          實現一個Redux(完善版)

          淺談React的Context API

          帶你實現 react-redux

          為什么要用 redux-thunk

          在使用 Redux 過程,通過 dispatch 方法派發一個 action 對象。當我們使用 redux-thunk 后,可以 dispatch 一個 function。redux-thunk會自動調用這個 function,并且傳遞 dispatch, getState 方法作為參數。這樣一來,我們就能在這個 function 里面處理異步邏輯,處理復雜邏輯,這是原來 Redux 做不到的,因為原來就只能 dispatch 一個簡單對象。


          用法

          redux-thunk 作為 redux 的中間件,主要用來處理異步請求,比如:


          export function fetchData() {

           return (dispatch, getState) => {

             // to do ...

             axios.get('https://jsonplaceholder.typicode.com/todos/1').then(res => {

               console.log(res)

             })

           }

          }

          redux-thunk 源碼

          redux-thunk 的源碼比較簡潔,實際就11行。前幾篇我們說到 redux 的中間件形式,

          本質上是對 store.dispatch 方法進行了增強改造,基本是類似這種形式:


          const middleware = (store) => next => action => {}

          在這里就不詳細解釋了,可以看 實現一個Redux(完善版)


          先給個縮水版的實現:


          const thunk = ({ getState, dispatch }) => next => action => {

             if (typeof action === 'function') {

                 return action(dispatch, getState)

             }

             return next(action)

          }

          export default thunk

          原理:即當 action 為 function 的時候,就調用這個 function (傳入 dispatch, getState)并返回;如果不是,就直接傳給下一個中間件。

          完整源碼如下:


          function createThunkMiddleware(extraArgument) {

           return ({ dispatch, getState }) => next => action => {

             // 如果action是一個function,就返回action(dispatch, getState, extraArgument),否則返回next(action)。

             if (typeof action === 'function') {

               return action(dispatch, getState, extraArgument)

             }

             // next為之前傳入的store.dispatch,即改寫前的dispatch

             return next(action)

           }

          }


          const thunk = createThunkMiddleware()

          // 給thunk設置一個變量withExtraArgument,并且將createThunkMiddleware整個函數賦給它

          thunk.withExtraArgument = createThunkMiddleware


          export default thunk

          我們發現其實還多了 extraArgument 傳入,這個是自定義參數,如下用法:


          const api = "https://jsonplaceholder.typicode.com/todos/1";

          const whatever = 10;


          const store = createStore(

           reducer,

           applyMiddleware(thunk.withExtraArgument({ api, whatever })),

          );


          // later

          function fetchData() {

           return (dispatch, getState, { api, whatever }) => {

             // you can use api and something else here

           };

          }

          總結

          同 redux-thunk 非常流行的庫 redux-saga 一樣,都是在 redux 中做異步請求等副作用。Redux 相關的系列文章就暫時寫到這部分為止,下次會寫其他系列。

          日歷

          鏈接

          個人資料

          藍藍設計的小編 http://m.sdgs6788.com

          存檔

          久久ZYZ资源站无码中文动漫| 一本一道久久精品综合| 97视频久久久| 久久久久亚洲av无码专区 | 欧美日韩中文字幕久久伊人| 青青草国产精品久久久久| 婷婷久久综合| 久久精品国产精品亚洲精品| 99久久精品国产毛片| 久久人人青草97香蕉| 久久综合丝袜日本网| 久久精品国产亚洲av麻豆图片| 99久久婷婷免费国产综合精品| 久久精品一区二区三区中文字幕 | 久久影院综合精品| 狠狠色丁香婷婷综合久久来来去| 久久精品国产99国产精品亚洲 | 久久久久99精品成人片| 亚洲精品无码久久久影院相关影片| 青青国产成人久久91网| 国产精品久久久香蕉| 国产99久久久国产精免费| 久久久免费精品re6| 一本久久a久久精品综合香蕉 | 久久这里只精品99re66| 国产精品成人久久久久久久| 久久综合狠狠综合久久综合88| 久久综合狠狠综合久久97色| 久久se精品一区二区| 性色欲网站人妻丰满中文久久不卡| 日韩美女18网站久久精品| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 青草影院天堂男人久久| 91精品国产91久久久久福利| 亚洲精品无码专区久久久 | 久久久久久青草大香综合精品| 91久久精一区二区三区大全| 国产精品女同久久久久电影院| 东方aⅴ免费观看久久av| 国产精品久久久久免费a∨| 久久人做人爽一区二区三区|