我們進到 Redux 的官網 首頁最下方,會看到官方提供的兩個 Plugin
React Redux、Redux Toolkit
兩者都是使用於 React 的套件,底層都是 Redux,差異在於提供的 function 不同
- React Redux:提供 React 跟 Redux 串接的 Function。
- Redux Toolkit:提供建立 Redux 相關架構的 Function。
兩個套件會搭配著使用。
Redux 官網其實有提供一個創建 React 時直接加入 Redux 作為模板的指令。
npx create-react-app redux-essentials-example --template redux
但是!
我們先不使用它,先從手動建立開始,再使用模板會更了解 Redux 的運作。
複習 Redux 資料流
在開始之前,我們先再複習一次這張圖
當使用者點擊按鈕產生了事件,事件會到 Event Handler ,Dispatch 一個 Action 傳送到 Store,經過 Reducer,針對進來的 Action 跟原本的 State 進行處理,處理完後回傳新的 State 再更新到 UI 中。
此次實作會分別建立 user、todo 兩個 State 儲存在 Store 中,以下為實際建立的 Flow
建立流程
- 建立應用程式中唯一的 Store。
- 建立 Store 裡面的多個 State (並給予初始值)和 Reducer。
- State 有了初始值後,就可以先將 State 傳遞至 UI(View),並確認有顯示出資料。
- 針對不同 State 建立 Action。
- Reducer 內建立針對每個 Action 的處理行為。
- 在 UI 中將事件透過 Dispatch,發動對應的 Action 進行處理。
前置作業
- 建立 React 專案
- 安裝 React Redux、Redux Toolkit
# If you use npm:
npm install @reduxjs/toolkit react-redux # Or if you use Yarn:
yarn add @reduxjs/toolkit react-redux
操作開始
Step1. 建立應用程式中唯一的 Store
- 先建立一個 redux 資料夾 redux 的相關檔案都會放在這裡。
--- 路徑:src/redux
- 建立 Store
--- 路徑:src/redux/store.jsimport { configureStore } from '@reduxjs/toolkit'
export default configureStore({
reducer: {
// reducers 會放在這裡
}
})
Step2. 建立 Store 裡面的多個 State (並給予初始值)和 Reducer。
- State 會放在個別的 Reducer 檔案中
- 接著將上方兩個 Reducers 放入 Store 中。
Step3. State 有了初始值後,就可以先將 State 傳遞至 UI(View),並確認有顯示出資料。
- 使用 Provider 將 store 傳遞至底下子元件中
- 使用 useSelector 取出 state
Step4. 針對不同 State 建立 Action。
Step5. Reducer 內建立針對每個 Action 的處理行為。
- 更新 todos.js、users.js
Step6. 在 UI(view) 中將事件透過 Dispatch,發動對應的 Action 進行處理。
結果
關於 devtools 的工具可以來這裡下載:Redux DevTools
使用 actionTypes 統一管理 type
我們在 action 以及 reducers 的檔案內都會使用到 action.type 那執行相對應的處理,因此我們可以建立 actionType.js 進行管理,有以下幾點好處:
- 打錯字會報錯
- 可以一目瞭然目前有哪些 action
這樣就完成了 redux 整個流程,程式碼中都有詳細的註解說明,此部分只是簡單的實作,可以再練習練習將 Todo 改成使用 Inut 欄位輸入的方式、新增 toggleIsDone 的 action
下一篇我們可以來使用看看 redux 提供的 template ~
重點筆記
- 「React Redux」提供 React 跟 Redux 串接的 Function;「Redux Toolkit」提供建立 Redux 相關架構的 Function。
- 在 Redux 概念中所有的 state 更新是不可變的,因此需要複製原有的 state 進行修改
- 須設定 state 初始值。
- 使用 「useSelect」取得 State。
- 使用「useDispatch」發出 action 至 reducer 進行處理。
- 使用「actionTypes」統一管理 type。