網站首頁 編程語言 正文
常見使用:
獲取數據案例:
import React, { useState, useEffect } from 'react';
import axios from 'axios';
function App() {
const [data, setData] = useState({ hits: [] });
useEffect(() => {
const fetchData = async () => {
const result = await axios(
'https://hn.algolia.com/api/v1/search?query=redux',
);
setData(result.data);
};
fetchData();
}, []);
return (
<ul>
{data.hits.map(item => (
<li key={item.objectID}>
<a href={item.url}>{item.title}</a>
</li>
))}
</ul>
);
}
export default App;
上面例子中,useState()用來生成一個狀態變量(data),保存獲取的數據;useEffect()的副效應函數內部有一個 async 函數,用來從服務器異步獲取數據。拿到數據以后,再用setData()觸發組件的重新渲染。
由于獲取數據只需要執行一次,所以上例的useEffect()的第二個參數為一個空數組
附線上運行代碼
useEffect() 的第二個參數說明
有時候,我們不希望useEffect()每次渲染都執行,這時可以使用它的第二個參數,使用一個數組指定副效應函數的依賴項,只有依賴項發生變化,才會重新渲染。
function Welcome(props) {
useEffect(() => {
document.title = `Hello, ${props.name}`;
}, [props.name]);
return <h1>Hello, {props.name}</h1>;
}
上面例子中,useEffect()的第二個參數是一個數組,指定了第一個參數(副效應函數)的依賴項(props.name)。只有該變量發生變化時,副效應函數才會執行。如果第二個參數是一個空數組,就表明副效應參數沒有任何依賴項。因此,副效應函數這時只會在組件加載進入 DOM 后執行一次,后面組件重新渲染,就不會再次執行。這很合理,由于副效應不依賴任何變量,所以那些變量無論怎么變,副效應函數的執行結果都不會改變,所以運行一次就夠了。
useEffect() 第一個函數參數的返回值
副效應是隨著組件加載而發生的,那么組件卸載時,可能需要清理這些副效應。
useEffect()允許返回一個函數,在組件卸載時,執行該函數,清理副效應。如果不需要清理副效應,useEffect()就不用返回任何值。
useEffect(() => {
const subscription = props.source.subscribe();
return () => {
subscription.unsubscribe();
};
}, [props.source]);
上面例子中,useEffect()在組件加載時訂閱了一個事件,并且返回一個清理函數,在組件卸載時取消訂閱。
實際使用中,由于副效應函數默認是每次渲染都會執行,所以清理函數不僅會在組件卸載時執行一次,每次副效應函數重新執行之前,也會執行一次,用來清理上一次渲染的副效應。
useEffect() 的注意點
使用useEffect()時,有一點需要注意。如果有多個副效應,應該調用多個useEffect(),而不應該合并寫在一起。
錯誤寫法:
function App() {
const [varA, setVarA] = useState(0);
const [varB, setVarB] = useState(0);
useEffect(() => {
const timeoutA = setTimeout(() => setVarA(varA + 1), 1000);
const timeoutB = setTimeout(() => setVarB(varB + 2), 2000);
return () => {
clearTimeout(timeoutA);
clearTimeout(timeoutB);
};
}, [varA, varB]);
return <span>{varA}, {varB}</span>;
}
上面的例子是錯誤的寫法,副效應函數里面有兩個定時器,它們之間并沒有關系,其實是兩個不相關的副效應,不應該寫在一起。正確的寫法是將它們分開寫成兩個useEffect()。
正確寫法:
function App() {
const [varA, setVarA] = useState(0);
const [varB, setVarB] = useState(0);
useEffect(() => {
const timeout = setTimeout(() => setVarA(varA + 1), 1000);
return () => clearTimeout(timeout);
}, [varA]);
useEffect(() => {
const timeout = setTimeout(() => setVarB(varB + 2), 2000);
return () => clearTimeout(timeout);
}, [varB]);
return <span>{varA}, {varB}</span>;
}
原文鏈接:https://blog.csdn.net/xiaodi520520/article/details/110169180
相關推薦
- 2022-06-13 nginx?location/區別詳解_nginx
- 2022-02-24 詳細整理Oracle中常用函數_oracle
- 2022-12-27 Go標準庫日志打印及同時輸出到控制臺與文件_Golang
- 2022-10-23 在Asp.net?core項目中使用WebSocket_實用技巧
- 2022-10-14 C語言數據結構之棧和隊列的實現及應用_C 語言
- 2022-09-13 Nginx報錯104:Connection?reset?by?peer問題的解決及分析_nginx
- 2022-10-22 Android深入分析屬性動畫源碼_Android
- 2022-06-24 Edge瀏覽器開發者工具代碼修改同步到Vscode中_網頁編輯器
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支