React 中的 useContext使用方法
useContext就是上下文
什么是上下文呢?
全局變量就是全局的上下文,全局都可以訪問(wèn)到它;上下文就是你運(yùn)行一段代碼,所要知道的所有變量
useContext使用的方法:
1.要先創(chuàng)建createContex
使用createContext創(chuàng)建并初始化
const C = createContext(null);
2.Provider 指定使用的范圍
在圈定的范圍內(nèi),傳入讀操作和寫操作對(duì)象,然后可以使用上下文
<C.Provider value={{n,setN}}>
這是爺爺
<Baba></Baba>
</C.Provider>3.最后使用useContext
使用useContext接受上下文,因?yàn)閭魅氲氖菍?duì)象,則接受的也應(yīng)該是對(duì)象
const {n,setN} = useContext(C);
案例:在孫子組件中使用爺爺組件中定義的變量n,并且進(jìn)行+1操作
import React, { createContext, useContext, useReducer, useState } from 'react'
import ReactDOM from 'react-dom'
// 創(chuàng)造一個(gè)上下文
const C = createContext(null);
function App(){
const [n,setN] = useState(0)
return(
// 指定上下文使用范圍,使用provider,并傳入讀數(shù)據(jù)和寫入據(jù)
<C.Provider value={{n,setN}}>
這是爺爺
<Baba></Baba>
</C.Provider>
)
}
function Baba(){
return(
<div>
這是爸爸
<Child></Child>
</div>
)
}
function Child(){
// 使用上下文,因?yàn)閭魅氲氖菍?duì)象,則接受也應(yīng)該是對(duì)象
const {n,setN} = useContext(C)
const add=()=>{
setN(n=>n+1)
};
return(
<div>
這是兒子:n:{n}
<button onClick={add}>+1</button>
</div>
)
}
ReactDOM.render(<App />,document.getElementById('root'));使用useContext在改變一個(gè)數(shù)據(jù)時(shí),是通過(guò)自己逐級(jí)查找對(duì)比改變的數(shù)據(jù)然后渲染,而不是通過(guò)數(shù)據(jù)響應(yīng)式來(lái)監(jiān)控變量的。
也就是說(shuō)在點(diǎn)擊+1操作后,React開(kāi)始從function App開(kāi)始執(zhí)行代碼了
到此這篇關(guān)于React 的 useContext 的使用的文章就介紹到這了,更多相關(guān)React useContext 使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
React中異步數(shù)據(jù)更新不及時(shí)問(wèn)題及解決
這篇文章主要介紹了React中異步數(shù)據(jù)更新不及時(shí)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
如何使用 React Router v6 在 React 中
面包屑在網(wǎng)頁(yè)開(kāi)發(fā)中的角色不可忽視,它們?yōu)橛脩籼峁┝艘环N跟蹤其在網(wǎng)頁(yè)中當(dāng)前位置的方法,并有助于網(wǎng)頁(yè)導(dǎo)航,本文介紹了如何使用react-router v6和bootstrap在react中實(shí)現(xiàn)面包屑,感興趣的朋友一起看看吧2024-09-09
詳解如何在React單頁(yè)面應(yīng)用中捕獲錯(cuò)誤
在當(dāng)前的Web開(kāi)發(fā)中,使用React構(gòu)建單頁(yè)面應(yīng)用(SPA)已經(jīng)成為一種常見(jiàn)的做法,然而,當(dāng)應(yīng)用程序遇到錯(cuò)誤時(shí),有可能會(huì)導(dǎo)致整個(gè)頁(yè)面崩潰,給用戶帶來(lái)不好的體驗(yàn),本文將介紹如何在React單頁(yè)面應(yīng)用中捕獲錯(cuò)誤,以防止整個(gè)頁(yè)面的崩潰,需要的朋友可以參考下2023-09-09
react16.8.0以上MobX在hook中的使用方法詳解
這篇文章主要為大家介紹了react16.8.0以上MobX在hook中的使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
使用React手寫一個(gè)對(duì)話框或模態(tài)框的方法示例
這篇文章主要介紹了使用React手寫一個(gè)對(duì)話框或模態(tài)框的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04

