技術問答
技術文章
iT 徵才
Tag
聊天室
2025 鐵人賽
登入/註冊
問答
文章
Tag
邦友
鐵人賽
搜尋
2024 iThome 鐵人賽
DAY
13
0
佛心分享-IT 人自學之術
【現在學React還來得及嗎?】30天Takeaway分享
系列 第
13
篇
【Day13】Reducer
16th鐵人賽
react
haruowang
2024-08-17 12:02:10
357 瀏覽
分享至
Takeaway
Reducer邏輯:讓「事件處理函數」派遣action給響應的「reducer函數」
如何使用useReducer:將setter的邏輯改成dispatch,確定下個狀態要幹嘛 → 寫reducer函數 → 宣告const [tasks, dispatch] = useReducer(reducer函數, 初始狀態);
useReducer可以實現簡易的Flux模式
Flux邏輯:先定義規則(action) → 把規則派遣給狀態管理處(reducer函數/store) → 狀態管理處根據規則更新狀態(state)
在事件處理函數裡dispatch({ action });
action裡通常會有type和id等資訊
寫action要把數種變化視為同一行為。譬如以「重置」代表重設好幾個列
reducer函數接受兩個參數:分別是tasks(初始狀態)和action(要幹嘛)
引入immer後,tasks當然也可以用draft來取代
比起if…else,reducer函數更常使用switch…case語句
Reducer的概念來自陣列方法的reduce
Reducer要寫的程式碼可能更多,但比State更適合用來測試和除錯
Reducer也比State適合更複雜的情境
useReducer的概念很像Redux,但是沒有global store和middleware的功能
useReducer搭配useContext,可以實作類似前者的功能
useReducer隱藏的第三個參數:初始函數(Init function)
初始函數可以實現惰性初始化(Lazy initialization),只有在初次render時會被調用。其目的是提升效能,同時可以把初始狀態抓出來另外做處理
其實useState的原始碼是用useReducer寫的
其實useState也可以做惰性初始化
留言
追蹤
檢舉
上一篇
【Day12】State managing 3
下一篇
【Day14】Context
系列文
【現在學React還來得及嗎?】30天Takeaway分享
共
30
篇
目錄
RSS系列文
訂閱系列文
4
人訂閱
26
【Day26】R3F 2
27
【Day27】R3F 3
28
【Day28】React Leaflet 1
29
【Day29】React Leaflet 2
30
【Day30】React Leaflet 3
完整目錄
熱門推薦
{{ item.subject }}
{{ item.channelVendor }}
|
{{ item.webinarstarted }}
|
{{ formatDate(item.duration) }}
直播中
立即報名
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
902
組
團體組數
37
組
累計文章數
11080
篇
完賽人數
105
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
看更多
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
17th鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
windows server
linux
css
react
熱門問題
Esxi 8.0版本上的虛擬機器, 安裝的作業系統是Windows Server 2025, 確定輸入的密碼是正確的, 無法登入(顯示密碼錯誤)
HP iLo Advanced trial license
在線求大神,千奧軟體主機怎麼安裝
因為網路磁碟的關係造成系統自動重新開機
Docker Compose 建立 GitLab 容器,執行器 Runner 運行流水線問題
windows server無法使用gpedit.msc
Java證照題目(main() method)
iatf16949資訊稽核
iatf16949資訊稽核內容
微軟更新重開機很久
熱門回答
iatf16949資訊稽核
Esxi 8.0版本上的虛擬機器, 安裝的作業系統是Windows Server 2025, 確定輸入的密碼是正確的, 無法登入(顯示密碼錯誤)
因為網路磁碟的關係造成系統自動重新開機
微軟更新重開機很久
windows server無法使用gpedit.msc
熱門文章
第4天,Cloudflare Public DNS 與 WARP / 滷小小 美味的滷味 | 30天板橋湳雅夜市
第5天,數位憑證的格式 PEM、DER / 小辣椒魷魚羹(台北萬華)| 30天滷肉飯
Day 17- 分離關注點:設定與主要邏輯分開
第5天,Cloudflare 的費用 / 潤餅捲 | 30天板橋湳雅夜市
[為你自己學 n8n] 第 5 天,JSON 不是人名!搞懂自動化的基礎語言!
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}