您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關Context怎么在React中應用,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
Context 提供了一種在組件之間共享數據的方式,而不必顯式地通過組件樹的逐層傳遞 props。
應用場景 哪些數據會需要共享?
Context 設計目的是為了共享那些對于一個組件樹而言是**“全局”的數據**,例如當前認證的用戶、主題或首選語言。
1. 創建并初始化Context
const MyContext = createContex(defaultValue);
創建一個 Context 對象。當 React 渲染一個訂閱了這個 Context 對象的組件,這個組件會從組件樹中離自身最近的那個匹配的 Provider
中讀取到當前的 context 值。
2. 訂閱Context
<MyContext.Provider value={/* 某個值 */}>
Provider 接收一個 value
屬性,傳遞給消費組件。一個 Provider 可以和多個消費組件有對應關系。多個 Provider 也可以嵌套使用,里層的會覆蓋外層的數據。
這里有兩個相關的概念
Provider - Context提供者,或Context的訂閱者。可以理解為通過Provider為其內部組件訂閱了Context值的變動,一旦Context值有變化,就會觸發內部組件重新渲染。
Comsumer - Context消費者(消費組件),或者叫Context使用者。即在Provider內部使用useContext()
來使用或消費Context的組件。這些組件通過useContext()獲取、使用Context的最新值。
3. 使用Conext
3.1 React組件中使用
const value = useContext(MyContext);
在消費組件中引用Context。value會從組件樹中離自身最近的那個匹配的Provider中讀取到當前的Context值。
3.2 純函數式組件中使用
在純函數式的組件中,可以使用Consumer
來引用context的值。如果沒有上層對應的Provider,value等同于傳遞給createContext()
的defaultValue
.
<MyContext.Consumer> {value => /* 基于 context 值進行渲染*/} </MyContext.Consumer>
4. Context的更新
4.1 自上而下更新Context
自上而下更新指的是更新Provider的value值。當 Provider 的 value
值發生變化時,它內部的所有消費組件內通過useContext
獲取到的值會自動更新,并觸發重新渲染。
//App.js // .... export default function App() { //... // const {contextValue, setContextValue} = React.useState(initialValue); // function to update the context value function updateContext(newValue) { // ... // 更新contextValue, ConsumerComponent1, ConsumerComponent2, ConsumerComponent3, ConsumerComponent11都會觸發重新渲染。 setContextValue(newValue) } ... return ( <App> <MyContext.Provider value={contextValue}> <ConsumerComponent1> <ConsumerComponent11> // .... </ComsumerComponent11> </ConsumerComponent1> <ConsumerComponent2 /> <ConsumerComponent3 /> </MyContext.Provider> </App> ); }
4.2 自下而上(從消費組件)更新Context
在某些情況下,需要在某個消費組件內更新context
,并且適配到整個程序。比如通過應用程序的setting
組件修改UI風格。 這時就需要通過回調將更新一層層傳遞到對應的Provider,更新Provide對應的value
,從而觸發所有相關消費組件的更新。
// app.js export default function App() { ... const {contextValue, setContextValue} = React.useState(initialValue); // function to update the context value function updateContext(newValue) { // ... // 更新contextValue, ConsumerComponent1, ConsumerComponent2, ConsumerComponent3, ConsumerComponent11都會觸發重新渲染。 setContextValue(newValue) } ... return ( <App> <MyContext.Provider value={contextValue}> <ConsumerComponent1> <ConsumerComponent11 updateValue={updateContext}> // 通過回調形式的props, 在ConsumerComponent11中更新contextValue, 因為contextValue屬于最頂層的Provider的值,所以也會觸發ConsumerComponent1, ConsumerComponent2, ConsumerComponent3重新渲染。 </ComsumerComponent11> </ConsumerComponent1> <ConsumerComponent2 /> <ConsumerComponent3 /> </MyContext.Provider> </App> ); }
4.3 Provider嵌套
在一些情況下,可能會出現同一個Context的provider嵌套的情況,這時候可以理解為兩個Context。不同的是,
... const {contextValue, setContextValue} = React.useState(initialValue); // function to update the context value function updateContext(newValue) { // ... // 更新contextValue, ConsumerComponent1, ConsumerComponent2, ConsumerComponent3, ConsumerComponent11都會觸發重新渲染。 setContextValue(newValue) } ... return ( <App> <MyContext.Provider value={contextValue}> <ConsumerComponent1> <ConsumerComponent11 /> </ConsumerComponent1> <ConsumerComponent2> ... // 如果只希望更新ComsumerComponent21, ComsumerComponent22中的值 const localContextValue = useContext(MyContext); // 從上一層Provider中獲取當前值 const {tempContextValue, setTempContextValue} = React.useState(localContextValue); function updateTempContext(newValue) { // 這里更新以后只會觸發ConsumerComponent21和ConsumerComponent22的重新渲染 setTempContextValue(newValue); } // 這里新建Provider,在ConsumerComponent21和ConsumerComponent22之間共享數據。 <MyContext.Provider value={tempValue}> <ConsumerComponent21> // 在ConsumerComponent21中通過useContext(MyContext)訂閱 // 獲取到的值為離自身最近的那個匹配的Provider中讀取到的Context值,即tempValue </ConsumerComponent21> <ConsumerComponent22> </ConsumerComponent22> </MyContext.Provider value={contextValue}> </ConsumerComponent2> <ConsumerComponent3 /> </MyContext.Provider> </App> );
以上就是Context怎么在React中應用,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。