1 首先注意到就是 useState
里面方法是異步的,所以不要在后面連續(xù)調(diào)用,由于react方法是批量異步調(diào)用,并不是每次調(diào)用修改方法都執(zhí)行,所以需要用到callback寫法 const [count, setCount] = useState(0); const add = () => { setCount(count + 1); setCount(count + 1); setCount(count + 1); setCount(count + 1);
// 就算執(zhí)行多次 其實(shí)還是會(huì)只執(zhí)行一次
//class組件是用一樣的 }; 修改后 const add = () => { setCount(count => count + 1);
//這種回調(diào)函數(shù)的寫法 setCount(count => count + 1); setCount(count => count + 1); setCount(count => count + 1);
// class組件 this.setState(prev=>({count: prev.count})) };
2 由于useState的是異步的,不要在修改后直接使用數(shù)據(jù)。
可以先修改數(shù)據(jù),判斷數(shù)據(jù),也可以利用useEffec,useMemo等等通過監(jiān)聽數(shù)據(jù)執(zhí)行 const [count, setCount] = useState(0); const add = () => { setCount(count + 1); if(count>=10) { // 一個(gè)邏輯這樣的寫的話會(huì)執(zhí)行上一次吃結(jié)果} }; 正確使用
1 const add = () => { let n = count +1 if(n){ //邏輯 } setCount(n) }; 正確
2 : const add = () => [ setCount(count+1) ] useEffect(()=>{ // 這里是邏輯 },[count])
3 useEffect hook的使用
useEffect 這個(gè)hook的使用,每一個(gè)消耗性能的內(nèi)容都可以通過return 來消除 useEffect(()=>{ // 邏輯1 return ()=>{ // 清楚邏輯1的副作用 } },[監(jiān)聽的值])
4 如果子組件是函數(shù)組件需要利用useImperativeHandle ,forWard
useRef 可以獲取組件的數(shù)據(jù),也可當(dāng)常量的值來使用,注意獲取數(shù)據(jù)使用的時(shí)候函數(shù)組件特別需要注意,如果子組件是函數(shù)組件需要利用useImperativeHandle ,forWard