React通過conetxt實現多組件傳值功能
更新時間:2021年10月21日 14:29:11 作者:明知山_
Context 提供了一種在組件之間共享此類值的方式,而不必顯式地通過組件樹的逐層傳遞 props。本文給大家介紹React通過conetxt實現多組件傳值功能,感興趣的朋友一起看看吧
該功能實現效果類似于vue的provide/inject
而React可通過context
進行完成
定義一個公共的文件context/Theme.jsx
import { createContext } from 'react'; const theme = createContext() export default theme
父組件引入公共文件及子組件
并傳遞theme值
import React, { useState } from 'react'; import Child from "@/components/Child.jsx" import Theme from "@/context/Theme.jsx" export default () => { const [theme, setTheme] = useState("blue") return ( <> <button onClick={() => setTheme("green")}>檢驗context是否為響應式</button> <Theme.Provider value={theme}> <Child /> </Theme.Provider> </> ) }
子組件獲取數據components/Child.jsx
import React from 'react'; import Theme from "@/context/Theme.jsx" export default () => { return ( <Theme.Consumer> {data => <p>接收父組件context傳遞的值:{data}</p>} </Theme.Consumer> ); }
到此這篇關于React通過conetxt實現多組件傳值的文章就介紹到這了,更多相關React多組件傳值內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
React腳手架config-overrides.js文件的配置方式
這篇文章主要介紹了React腳手架config-overrides.js文件的配置方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10react中使用redux-persist做持久化儲存的過程記錄
這篇文章主要介紹了react中使用redux-persist做持久化儲存的相關資料,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2024-01-01