React組件通信——context(提供者/消費者)

Context 是 React 提供的一種組件間通信方式,主要用于解決跨層級組件 props 傳遞的問題。它允許數據在組件樹中"跨級"傳遞,無需顯式地通過每一層 props 向下傳遞。

一、Context 核心概念

1. 基本組成

  • React.createContext:創建 Context 對象

  • Context.Provider:提供數據的組件

  • Context.Consumer?或?useContext:消費數據的組件

2. 工作原理

二、示例

創建 Context 文件(獨立模塊)

// contexts/ThemeContext.js
import { createContext } from 'react';// 1. 創建Context并導出
const ThemeContext = createContext('light'); // 默認值// 2. 導出Provider組件
export const ThemeProvider = ThemeContext.Provider;// 3. 直接導出Context對象
export default ThemeContext;

提供者文件

// App.js
import React, { useState } from "react";
import { ThemeProvider } from "./contexts/ThemeContext";
import ThemedButton from "./ThemeButton";function App() {const [theme, setTheme] = useState("dark");return (<ThemeProvider value={theme}><ThemedButton /><button onClick={() => setTheme(theme === "dark" ? "light" : "dark")}>切換主題</button></ThemeProvider>);
}export default App;

消費者文件

// ThemedButton.js
import React, { useContext } from "react";
import ThemeContext from "./contexts/ThemeContext";function ThemedButton() {// 方式一:使用從Context文件導入的同一個Context對象const theme = useContext(ThemeContext);return (<div><buttonstyle={{background: theme === "dark" ? "#333" : "#EEE",color: theme === "dark" ? "white" : "black",}}>當前主題: {theme}</button>{/* 方式二:適用于class組件 */}<ThemeContext.Consumer>{(theme) => {return (<buttonstyle={{background: theme === "dark" ? "#333" : "#EEE",color: theme === "dark" ? "white" : "black",}}>當前主題: {theme}</button>);}}</ThemeContext.Consumer></div>);
}export default ThemedButton;

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/85258.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/85258.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/85258.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

“微信短劇小程序開發指南:從架構設計到上線“

1. 引言&#xff1a;短劇市場的機遇與挑戰 近年來&#xff0c;短視頻和微短劇市場呈現爆發式增長&#xff0c;用戶碎片化娛樂需求激增。短劇小程序憑借輕量化、社交傳播快、變現能力強等特點&#xff0c;成為內容創業的新風口。然而&#xff0c;開發一個穩定、流暢且具備商業價…

RPC與RESTful對比:兩種API設計風格的核心差異與實踐選擇

# RPC與RESTful對比&#xff1a;兩種API設計風格的核心差異與實踐選擇 ## 一、架構哲學與設計目標差異 1. **RPC&#xff08;Remote Procedure Call&#xff09;** - **核心思想**&#xff1a;將遠程服務調用偽裝成本地方法調用&#xff08;方法導向&#xff09; - 典型行為…

【pytest進階】pytest之鉤子函數

什么是 hook (鉤子)函數 經常會聽到鉤子函數(hook function)這個概念,最近在看目標檢測開源框架mmdetection,里面也出現大量Hook的編程方式,那到底什么是hook?hook的作用是什么? what is hook ?鉤子hook,顧名思義,可以理解是一個掛鉤,作用是有需要的時候掛一個東西…

深度學習計算——動手學深度學習5

環境&#xff1a;PyCharm python3.8 1. 層和塊 塊&#xff08;block&#xff09;可以描述 單個層、由多個層組成的組件或整個模型本身。 使用塊進行抽象的好處&#xff1a; 可將塊組合成更大的組件(這一過程通常是遞歸) 如 圖5.1.1所示。通過定義代碼來按需生成任意復雜度…

NodeJS的fs模塊的readFile和createReadStream區別以及常見方法

Node.js 本身沒有像 Java 那樣嚴格區分字符流和字節流&#xff0c;區別主要靠編碼&#xff08;encoding&#xff09;來控制數據是以 Buffer&#xff08;二進制字節&#xff09;形式還是字符串&#xff08;字符&#xff09;形式處理。 詳細解釋&#xff1a; 方面JavaNode.js字節…

基于二進制XOR運算的機器人運動軌跡與對稱圖像自動生成算法

原創&#xff1a;項道德&#xff08;daode3056,daode1212&#xff09; 新的算法出現&#xff0c;往往能給某些行業與產業帶來革命與突破。為探索機器人運動軌跡與對稱圖像自動生成算法&#xff0c;本人已經通過18種算法的測試&#xff0c;最終&#xff0c;以二進制的XOR運算為…

Spring AI 項目實戰(七):Spring Boot + Spring AI Tools + DeepSeek 智能工具平臺(附完整源碼)

系列文章 序號文章名稱1Spring AI 項目實戰(一):Spring AI 核心模塊入門2Spring AI 項目實戰(二):Spring Boot + AI + DeepSeek 深度實戰(附完整源碼)3Spring AI 項目實戰(三):Spring Boot + AI + DeepSeek 打造智能客服系統(附完整源碼)4Spring AI 項目實戰(四…

spring-webmvc @RequestHeader 典型用法

典型用法 基礎用法&#xff1a;獲取指定請求頭值 GetMapping("/info") public String getInfo(RequestHeader("User-Agent") String userAgent) {return "User-Agent: " userAgent; }如果請求中包含 User-Agent 請求頭&#xff0c;則其值將被…

Ubuntu:20.04中安裝docker

是的&#xff0c;您列出的命令是完整的安裝步驟&#xff0c;但為了確保100%可靠性和處理可能的問題&#xff0c;我建議進行以下優化和補充&#xff1a; 完整優化的安裝腳本&#xff08;包含錯誤處理和驗證&#xff09; #!/bin/bash# 1. 徹底清理舊版本和配置 sudo apt remove…

大數據實時風控引擎:Spark Streaming、Kafka、Flink與Doris的融合實踐

大數據實時風控引擎&#xff1a;Spark Streaming、Kafka、Flink與Doris的融合實踐 在數字金融、電商交易與在線服務的核心戰場&#xff0c;風險控制能力已成為業務的生命線。傳統批量風控模式在應對瞬息萬變的欺詐攻擊、信用風險時捉襟見肘。本文將深入探討如何利用**Spark St…

【創龍瑞芯微 RK3576 全國產 ARM 八核 2.2GHz 工業開發板-硬件說明書】

前 言 本文主要介紹TL3576-EVM評估板硬件接口資源以及設計注意事項等內容。 RK3576J/RK3576處理器的IO電平標準一般為1.8V、3.3V,上拉電源一般不超過3.3V或1.8V,當外接信號電平與IO電平不匹配時,中間需增加電平轉換芯片或信號隔離芯片。按鍵或接口需考慮ESD設計,ESD器件…

一文吃透ADB,從入門到精通

目錄 一、ADB 簡介1.1 什么是 ADB1.2 ADB 的工作原理1.3 ADB 的安裝與環境配置 二、ADB 基礎命令2.1 設備連接相關命令2.2 應用管理命令2.3 文件傳輸命令 三、ADB 高級命令3.1 ADB Shell 深入探究3.2 日志查看與分析3.3 設備信息獲取3.4 屏幕操作與錄制 四、ADB 常見問題與解決…

PostgreSQL高可用架構設計與實踐指南

# PostgreSQL高可用架構設計與實踐指南 ## 一、高可用性核心訴求 PostgreSQL作為企業級關系型數據庫&#xff0c;高可用設計需要滿足以下關鍵指標&#xff1a; - 故障恢復時間&#xff08;RTO&#xff09;&#xff1a;秒級到分鐘級自動切換能力 - 數據損失容忍度&#xff0…

今天我想清楚了

首先說一聲抱歉&#xff0c;很多天沒有更新了&#xff0c;因為在我這里&#xff0c;我的內心感到迷茫&#xff0c;從來沒有這樣過&#xff0c;不知道為什么自己一直要做的事&#xff0c;進度太慢了&#xff0c;因為我的人生是空虛的&#xff0c;我感覺我做的不夠好&#xff0c;…

代碼隨想錄day3鏈表1

new關鍵字 1.new是一個關鍵字&#xff0c;用于開辟空間&#xff0c;開辟的空間在堆上&#xff0c;而一般聲明的變量存放在棧上&#xff1b; 2.new得到的是一段空間的首地址。所以一般需要用指針來存放這段地址 new int(10);//返回new出來這塊內存的地址int *pnew int(10);//…

taro小程序如何實現新用戶引導功能?

一、需求背景 1、需要實現小程序新功能引導 2、不使用第三方庫&#xff08;第三方組件試了幾個&#xff0c;都是各種兼容性問題&#xff0c;放棄&#xff09; 二、實現步驟 1、寫一個公共的guide組件&#xff0c;代碼如下 components/Guide/index.tsx文件 import React, { …

鍵盤動作可視化技術淺析:如何做到低延遲顯示

在做屏幕錄制或者操作演示的時候&#xff0c;你是否遇到過這樣的問題&#xff1a;觀眾看不清你按了哪個鍵、點了哪里&#xff1f;這是能完美解決這個問題的小工具Keyviz。它可以把你的鍵盤輸入和鼠標點擊實時顯示在屏幕上&#xff0c;清晰直觀&#xff0c;特別適合教學、錄屏、…

Prufer序列 學習筆記

文章目錄 P r u f e r Prufer Prufer 序列對樹建立 P r u f e r Prufer Prufer 序列對 P r u f e r Prufer Prufer 序列重建樹 應用Cayley 公式[HNOI2004] 樹的計數「雅禮集訓 2017 Day8」共[THUPC 2018] 城市地鐵規劃CF156D Clues[ARC106F] Figures P r u f e r Prufer Pruf…

高性能場景使用Protocol Buffers/Apache Avro進行序列化怎么實現呢

我們以Protocol Buffers&#xff08;Protobuf&#xff09;和Apache Avro為例&#xff0c;分別展示高性能序列化的實現方式。 由于兩者都需要定義Schema&#xff0c;然后生成代碼&#xff0c;因此步驟包括&#xff1a; 1. 定義Schema文件 2. 使用工具生成Java類 3. 在代碼中…

iOS端網頁調試 debug proxy策略:項目中的工具協同實踐

移動開發中的調試&#xff0c;一直是效率瓶頸之一。特別是當前 Web 前端與 App 原生高度耦合的背景下&#xff0c;頁面調試不僅受限于瀏覽器&#xff0c;還要面對 WebView 實現差異、系統權限控制、設備多樣性等復雜情況。 但我們是否可以構建一套**“設備無關”的調試工作流*…