React hooks使用方法全面匯總
1. 前言
react16.8推出hooks更好的支持函數(shù)組件,使用函數(shù)組件更容易進(jìn)行代碼的復(fù)用,拓展性更強(qiáng)。
2. useState
useState類似于class組件的state功能,用于更新視圖
import React, { Component, useState } from 'react'; export default function Hello() { const [count, setCount] = useState(0); //設(shè)置默認(rèn)值為0 return <div> {count} <button onClick={()=>setCount(count + 1)}>增加</button> </div> } //useState還可以使用函數(shù)進(jìn)行賦值 const [count, setCount] = useState(()=>0); //設(shè)置默認(rèn)值為0
3. useEffect
useEffect接受兩個參數(shù),第一個參數(shù)是要執(zhí)行的回調(diào)函數(shù),第二個參數(shù)是依賴的參數(shù),如下面的例子里只有當(dāng)count發(fā)生變化的時候才會打印count,當(dāng)?shù)诙€參數(shù)為空數(shù)組的時候,組件在渲染完成后會執(zhí)行一次,第二個參數(shù)不傳遞的時候每次渲染都會執(zhí)行
export default function Hello() { const [count, setCount] = useState(() => 0); //設(shè)置默認(rèn)值為0 // useEffect useEffect(() => { }, [count]) return <div> {count} <button onClick={() => setCount(count + 1)}>增加</button> </div> }
帶有返回值的useEffect用于清除執(zhí)行過程中的副作用
useEffect(()=>{ const timer = setInterval(() => { console.log(count); }, 1000); window.addEventListener('resize',handleResize); return function(){ clearInterval(timer); window.removeEventListener('resize',handleResize); } }, [count])
如果每次執(zhí)行useEffect都定義一個定時器,那定時器會越來越多,通過在返回函數(shù)中清除定時器取消這個副作用。useEffect返回函數(shù)的執(zhí)行時機(jī)是下一次useEffect執(zhí)行之前。
利用這一點(diǎn)可以實(shí)現(xiàn)防抖和節(jié)流函數(shù)
4. useLayoutEffect
dom渲染之前的useEffect: useLayoutEffect =》 dom渲染 =》useLayout
export default function Hello (props){ const [count, setCount] = useState(0); useEffect(()=>{ console.log('useEffect'); },[count]); useLayoutEffect(()=>{ console.log('useLayoutEffect'); },[count]) return <div> {count} <button onClick={()=> setCount(count+1)}>增加</button>; </div> }
使用useEffect和useLayoutEffect去更新視圖狀態(tài)會產(chǎn)生不同的效果,useEffect會有一個狀態(tài)到另一個狀態(tài)的過程(閃動效果),useLayoutEffect直接渲染最終狀態(tài)
5. useMemo
useMemo的作用就是緩存,減少代碼的執(zhí)行次數(shù)。
下面的代碼點(diǎn)擊按鈕count狀態(tài)發(fā)生變化,整個Hello函數(shù)體內(nèi)的代碼都會執(zhí)行,每次點(diǎn)擊按鈕都會打印str的值
export default function Hello (props){ const [count, setCount] = useState(0); const [str, setStr] = useState('hello hooks!'); useEffect(()=>{ console.log('useEffect'); },[count]); console.log('str'); //每次渲染都會執(zhí)行 return <div> {count} {str} <button onClick={()=> setCount(count+1)}>增加</button> </div> }
使用useMemeo進(jìn)行緩存,當(dāng)str發(fā)生變化的時候再執(zhí)行打印語句
useMemo(()=>{ console.log(str); },[str])
useMemo還可以用來緩存函數(shù)
export default function Hello (props){ const [count, setCount] = useState(0); const [str, setStr] = useState('hello hooks!'); useEffect(()=>{ console.log('useEffect'); },[count]); // 使用useMemo緩存函數(shù) const hanldeClick = useMemo(()=>{ return function(){ console.log(count); }; },[count]); return <div> {count} {str} <button onClick={()=> setCount(count+1)}>增加</button> <button onClick={hanldeClick}>測試</button> </div> }
6. useCallback
useCallback的功能是緩存函數(shù),取的是useMemo的運(yùn)行結(jié)果
const handleClick = useMemo(()=>{ return function(){ console.log(count); }; },[count]); const handleClick = useCallback(()=>{ console.log(count); },[count])
上面兩個實(shí)現(xiàn)的功能是一樣的,在平時的開發(fā)中要盡量使用useMemo去緩存函數(shù)
7. useRef
- 獲取元素dom ref.current
- 緩存數(shù)據(jù)
使用useRef獲取元素
export default function Hello(props) { const ref = useRef(null); useEffect(() => { console.log(ref.current); // <input id='input'> }) return <div> <input ref={ref} id="input" /> </div> }
使用useRef保存數(shù)據(jù),當(dāng)ref.current發(fā)生變化的時候視圖不會重新渲染
export default function Hello(props) { const ref = useRef(null); useEffect(() => { ref.current = 'hello hooks!'; }); return <div> <span> {ref.current}</span> </div> }
8. useReducer
useReducer用于更新復(fù)雜的state提升渲染性能,使用方法與redux類似。與redux的區(qū)別是redux管理的是全局的數(shù)據(jù)做數(shù)據(jù)共享,useReducer是useState的替代方案,只管理單個組件的狀態(tài)。
onst reducer = (state, action) => { switch (action.name) { case 'increment': return { count: state.count + 1 }; case 'decrement': return { count: state.count - 1 }; default: return state; } }; const initState = { count: 0 }; export default function Hello() { const [state, dispatch] = useReducer(reducer, initState) return <div> <span> {state.count}</span> <button onClick={() => dispatch({ name: 'increment' })}>增加</button> <button onClick={() => dispatch({ name: 'decrement' })}>減少</button> </div> }
9. useContext
useContext用來解決props層層傳遞,嵌套很深的問題。
export default function Father() { const [count, setCount] = useState(0); const handleClick = useCallback(() => { setCount(count + 1); }, [count]); return <div> {count} <button onClick={() => handleClick()}>增加</button> <MyContext.Provider value={{ count }}> <Children /> </MyContext.Provider> </div> }; function Children() { const context = useContext(MyContext); return <div> 父組件的count: {context.count} </div> };
10. memo
在calss組件中通過對比props,子組件接收的props發(fā)生變化的時候才進(jìn)行更新渲染,在函數(shù)組件中沒有識別props的能力,當(dāng)父組件重新渲染的時候子組件也會重新渲染,在使用memo包裹后只有props發(fā)生變化的時候才會重新渲染。memo的功能類似于calss組件對pureComponent對props進(jìn)行了淺比較。
export default function Father() { const [count, setCount] = useState(0); const [str, setStr] = useState('hello hooks!'); return <div> {count} {str} <button onClick={() => setCount(count + 1)}>增加count</button> <button onClick={() => setStr(str + 1)}>修改str</button> <Children count={count} /> </div> }; const Children = React.memo(function Children(props) { console.log('子組件渲染'); return <div> 子組件: {props.count} </div> } );
上面的例子中,count變化的時候子組件渲染更新,str變化的時候子組件不重新渲染。
到此這篇關(guān)于React hooks使用方法全面匯總的文章就介紹到這了,更多相關(guān)React hooks內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react簡單實(shí)現(xiàn)防抖和節(jié)流
在日常開發(fā)中,我們經(jīng)常會有防抖和節(jié)流的需要,可以減小服務(wù)器端壓力,提升用戶體驗(yàn),本文就詳細(xì)的介紹了react簡單實(shí)現(xiàn)防抖和節(jié)流,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05Create?react?app修改webapck配置導(dǎo)入文件alias
這篇文章主要為大家介紹了Create?react?app修改webapck配置導(dǎo)入文件alias,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12阿里低代碼框架lowcode-engine自定義設(shè)置器詳解
這篇文章主要為大家介紹了阿里低代碼框架lowcode-engine自定義設(shè)置器示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02React.js入門實(shí)例教程之創(chuàng)建hello world 的5種方式
React 是近期非常熱門的一個前端開發(fā)框架。應(yīng)用非常廣泛,接下來通過本文給大家介紹React.js入門實(shí)例教程之創(chuàng)建hello world 的5種方式 ,需要的朋友參考下吧2016-05-05React實(shí)現(xiàn)二級聯(lián)動效果(樓梯效果)
這篇文章主要為大家詳細(xì)介紹了React實(shí)現(xiàn)二級聯(lián)動效果,樓梯效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09