技術問答
技術文章
iT 徵才
Tag
聊天室
2025 鐵人賽
登入/註冊
問答
文章
Tag
邦友
鐵人賽
搜尋
2024 iThome 鐵人賽
DAY
16
0
佛心分享-IT 人自學之術
【現在學React還來得及嗎?】30天Takeaway分享
系列 第
16
篇
【Day16】Effect1
16th鐵人賽
react
haruowang
2024-08-20 15:09:20
382 瀏覽
分享至
Takeaway
讓組件和React之外的系統同步
一般來說,副作用得在事件處理函數裡發生。但要是沒有特定的觸發事件,就可以使用Effect包裹副作用
不要太常使用Effect
編寫Effect的三步驟:宣告 → 指定 → (清理)
Effect預設會在每次渲染後執行,所以要指定依賴
React使用Object.is來確認依賴項是否發生變化
如果依賴項不會改變,可以不用特別清理
依賴陣列如果設定空陣列,代表組件掛載後才會執行useEffect
ref和set函數都是穩定的,所以不用放進依賴陣列
但如果無法確認傳來的是不是同個ref等等,就要放了
開發環境下,會連接兩次,斷開一次。React會多測試,不要用ref阻止
利用useEffect處理非同步請求fetch時,可能會因為請求切換太快,而遇到競態條件(Race Condition)。不引入其他套件的應對方式有AbortController
關於切換太快的效能優化方式還有節流(Throttle)函式
如果想要緩存資料而不是刪掉再請求:可使用React Query、useSWR和 React Router v6.4+等第三方解決方案
Intersection Observer:常用來觀察元素在視窗裡的可視程度
如果要使用的資料只需要載入一次,如確認登入狀態或使用本地資料,可以寫在useEffect之外
業務邏輯(如按鈕購買)不該放在useEffect裡,而該寫到事件處理函數
留言
追蹤
檢舉
上一篇
【Day15】ref
下一篇
【Day17】Effect2
系列文
【現在學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
組
累計文章數
19858
篇
完賽人數
529
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
看更多
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
17th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
linux
windows server
css
react
熱門問題
從資訊安全角度分析:若電子支付平台疑遭暗網販售資料,可能的技術成因與防護機制?
win11 bitlocker 除了格式化重灌外, 有解嗎?
請問要如何將github下載下來的檔案轉成dll檔
Exchange 2016 手機無法登入
Gmail 寄件備分 一次變成 Gmail聯絡人寄出
二道認證認證的方式
VGA一公二母連接線的公頭插到螢幕上也可以使用嗎?
熱門回答
從資訊安全角度分析:若電子支付平台疑遭暗網販售資料,可能的技術成因與防護機制?
請問要如何將github下載下來的檔案轉成dll檔
熱門文章
📨 用 n8n 自動整理信用卡帳單:從 Gmail 到 LINE 的實戰筆記
Google AI 搜尋的負面影響逐漸浮現
[IIS]更版時客戶想要有個美美的靜態維護畫面嗎? 其實超簡單的方法就可以辦到咯
Cisco 300-820 CLCEI 認證考試介紹|CCNP Collaboration 專業方向與備考指南
Wifi定位技術,802.11mc,GPS,AGPS,WiGLE
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}