React中的Hooks進階理解教程
Hooks進階
useState - 回調(diào)函數(shù)的參數(shù)
使用場景
參數(shù)只會在組件的初始渲染中起作用,后續(xù)渲染時會被忽略。如果初始 state 需要通過計算才能獲得,則可以傳入一個函數(shù),在函數(shù)中計算并返回初始的 state,此函數(shù)只在初始渲染時被調(diào)用
語法
const [name, setName] = useState(()=>{ // 編寫計算邏輯 return '計算之后的初始值'})
語法規(guī)則
- 回調(diào)函數(shù)return出去的值將作為
name
的初始值 - 回調(diào)函數(shù)中的邏輯只會在組件初始化的時候執(zhí)行一次
語法選擇
- 如果就是初始化一個普通的數(shù)據(jù) 直接使用
useState(普通數(shù)據(jù))
即可 - 如果要初始化的數(shù)據(jù)無法直接得到需要通過計算才能獲取到,使用
useState(()=>{})
需求
import { useState } from 'react' function Counter(props) { const [count, setCount] = useState(() => { return props.count }) return ( <div> <button onClick={() => setCount(count + 1)}>{count}</button> </div> ) } function App() { return ( <> <Counter count={10} /> <Counter count={20} /> </> ) } export default App
useEffect - 清理副作用
使用場景
在組件被銷毀時,如果有些副作用操作需要被清理,就可以使用此語法,比如常見的定時器
語法及規(guī)則
useEffect(() => { console.log('副作用函數(shù)執(zhí)行了') // 副作用函數(shù)的執(zhí)行時機為: 在下一次副作用函數(shù)執(zhí)行之前執(zhí)行 return () => { console.log('清理副作用的函數(shù)執(zhí)行了') // 在這里寫清理副作用的代碼 } })
定時器示例
添加副作用函數(shù)前:組件雖然已經(jīng)不顯示了,但是定時器依舊在運行
import { useEffect, useState } from 'react' function Foo() { useEffect(() => { setInterval(() => { console.log('副作用函數(shù)執(zhí)行了') }, 1000) }) return <div>Foo</div> } function App() { const [flag, setFlag] = useState(true) return ( <> <button onClick={() => setFlag(false)}>click</button> {flag ? <Foo/> : null} </> ) } export default App
添加清理副作用函數(shù)后:一旦組件被銷毀,定時器也被清理
import { useEffect, useState } from 'react' function Foo() { useEffect(() => { const timerId = setInterval(() => { console.log('副作用函數(shù)執(zhí)行了') }, 1000) // 添加清理副租用函數(shù) return () => { clearInterval(timerId) } }) return <div>Foo</div> } function App() { const [flag, setFlag] = useState(true) return ( <> <button onClick={() => setFlag(false)}>click</button> {flag ? <Foo/> : null} </> ) } export default App
useEffect - 發(fā)送網(wǎng)絡(luò)請求
使用場景
如何在useEffect中發(fā)送網(wǎng)絡(luò)請求,并且封裝同步 async await操作
語法要求
不可以直接在useEffect的回調(diào)函數(shù)外層直接包裹 await ,因為異步會導(dǎo)致清理函數(shù)無法立即返回
useEffect(async ()=>{ const res = await axios.get('http://geek.itheima.net/v1_0/channels') console.log(res) },[])
正確寫法
在內(nèi)部單獨定義一個函數(shù),然后把這個函數(shù)包裝成同步
useEffect(()=>{ async function fetchData(){ const res = await axios.get('http://geek.itheima.net/v1_0/channels') console.log(res) } },[])
useRef
本節(jié)任務(wù):
能夠掌握使用useRef獲取真實dom或組件實例的方法
使用場景
在函數(shù)組件中獲取真實的dom元素對象或者是組件對象
使用步驟
- 導(dǎo)入
useRef
函數(shù) - 執(zhí)行
useRef
函數(shù)并傳入null,返回值為一個對象 內(nèi)部有一個current屬性存放拿到的dom對象(組件實例) - 通過ref 綁定 要獲取的元素或者組件
獲取dom
import { useEffect, useRef } from 'react' function App() { const h1Ref = useRef(null) useEffect(() => { console.log(h1Ref) },[]) return ( <div> <h1 ref={ h1Ref }>this is h1</h1> </div> ) } export default App
獲取組件實例
函數(shù)組件由于沒有實例,不能使用ref獲取,如果想獲取組件實例,必須是類組件
Demo.js
class Foo extends React.Component { sayHi = () => { console.log('say hi') } render(){ return <div>Foo</div> } } export default Foo
App.js
import { useEffect, useRef } from 'react' import Foo from './Demo' function App() { const h1Foo = useRef(null) useEffect(() => { console.log(h1Foo) }, []) return ( <div> <Foo ref={ h1Foo } /></div> ) } export default App
useContext
實現(xiàn)步驟
- 使用
createContext
創(chuàng)建Context對象 - 在頂層組件通過
Provider
提供數(shù)據(jù) - 在底層組件通過
useContext
函數(shù)獲取數(shù)據(jù)
代碼實現(xiàn)
import { createContext, useContext } from 'react' // 創(chuàng)建Context對象 const Context = createContext() function Foo() { return <div>Foo <Bar/></div> } function Bar() { // 底層組件通過useContext函數(shù)獲取數(shù)據(jù) const name = useContext(Context) return <div>Bar {name}</div> } function App() { return ( // 頂層組件通過Provider 提供數(shù)據(jù) <Context.Provider value={'this is name'}> <div><Foo/></div> </Context.Provider> ) } export default App
到此這篇關(guān)于React中的Hooks進階理解的文章就介紹到這了,更多相關(guān)React中的Hooks內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
從零開始搭建webpack+react開發(fā)環(huán)境的詳細(xì)步驟
這篇文章主要介紹了從零開始搭建webpack+react開發(fā)環(huán)境的詳細(xì)步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05webpack+react+antd腳手架優(yōu)化的方法
本篇文章主要介紹了webpack+react+antd腳手架優(yōu)化的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04React如何解決fetch跨域請求時session失效問題
這篇文章主要給大家介紹了關(guān)于React如何解決fetch跨域請求時session失效問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11React 使用recharts實現(xiàn)散點地圖的示例代碼
這篇文章主要介紹了React 使用recharts實現(xiàn)散點地圖的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12Electron整合React使用搭建開發(fā)環(huán)境的步驟詳解
這篇文章主要介紹了Electron整合React使用搭建開發(fā)環(huán)境,本文分步驟給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值 ,需要的朋友可以參考下2020-06-06