WHAT - React 組件的 props.children 屬性

目錄

  • 一、什么是 children
  • 二、基本用法
  • 三、類型定義(TypeScript)
  • 四、一些高級用法
    • 1. 條件渲染 children
    • 2. 多個 children 插槽(命名插槽)
  • 五、children 的優勢
  • 總結

在 React 中,children 是一個非常重要且特殊的 內置屬性,它表示組件標簽之間的嵌套內容。

一、什么是 children

舉個例子:

const MyCard = ({ children: React.ReactNode }) => {return <div className="card"><div>title</div>{children}</div>;
};<MyCard><p>這是卡片內容</p>
</MyCard>

在這個例子中:

  • <p>這是卡片內容</p> 就是傳給 MyCardchildren
  • MyCard 組件可以通過 props.children 訪問到它

二、基本用法

const Wrapper = ({ children }: { children: React.ReactNode }) => {return <div className="wrapper">{children}</div>;
};// 使用
<Wrapper><h1>Hello</h1><p>World</p>
</Wrapper>

Wrapper 中,children 就是一個 ReactNode 類型的元素數組。

三、類型定義(TypeScript)

常用類型寫法:

類型描述
React.ReactNode最常用,支持所有可渲染內容(JSX、字符串、null、數組等)
React.ReactElement更嚴格,只允許一個有效的 React 元素
ReactNode[]明確是多個節點(不推薦,ReactNode 已包含)
type Props = {children: React.ReactNode;
};

四、一些高級用法

1. 條件渲染 children

const ConditionalBox = ({ children, visible }: { children: React.ReactNode; visible: boolean }) => {return visible ? <div>{children}</div> : null;
};

2. 多個 children 插槽(命名插槽)

const Layout = ({ header, content }: { header: React.ReactNode; content: React.ReactNode }) => (<div><div>{header}</div><main>{content}</main></div>
);<Layout header={<h1>頭部</h1>}content={<p>正文內容</p>}
/>

五、children 的優勢

  • ? 靈活嵌套
  • ? 適合做布局容器組件、UI 包裹組件
  • ? 組合式組件(如 Card, Modal, Tabs)幾乎都依賴 children

總結

內容
定義children 是組件內部嵌套的內容
類型React.ReactNode 最常用
用途實現通用組件、插槽功能
特點靈活、結構清晰、提升復用性

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

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

相關文章

Spring Boot開發三板斧:高效構建企業級應用的核心技法

&#x1f9d1; 博主簡介&#xff1a;CSDN博客專家、CSDN平臺優質創作者&#xff0c;獲得2024年博客之星榮譽證書&#xff0c;高級開發工程師&#xff0c;數學專業&#xff0c;擁有高級工程師證書&#xff1b;擅長C/C、C#等開發語言&#xff0c;熟悉Java常用開發技術&#xff0c…

實戰篇-梳理時鐘樹

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 文章目錄 前言一、pandas是什么&#xff1f;二、使用步驟 1.引入庫2.讀入數據 總結 前言 這是B站傅里葉的貓視頻的筆記 一、建立工程 以Vivado的wave_gen為例子。為了引入異…

圖靈逆向——題六-倚天劍

從第六題開始就要有個先看看請求頭的習慣了[doge]。 別問博主為什么要你養成這個習慣&#xff0c;問就是博主被坑過。。。 headers里面有一個加密參數S&#xff0c;然后你就去逆向這個S對吧。 然后一看響應&#xff1a; 好家伙返回的還是個密文&#xff0c;所以要兩次逆向咯。…

ubuntu自動更新--unattended-upgrades

ubuntu自動更新--unattended-upgrades 1 介紹2 發展歷程3 配置與使用4 disable Auto update服務命令 參考 1 介紹 Unattended-Upgrades 是一個用于自動更新 Debian 及其衍生系統&#xff08;如 Ubuntu&#xff09;的工具。它的主要功能是自動檢查、下載并安裝系統更新&#xf…

從 Excel 到你的表格應用:條件格式功能的嵌入實踐指南

一、引言 在日常工作中&#xff0c;面對海量數據時&#xff0c;如何快速識別關鍵信息、發現數據趨勢或異常值&#xff0c;是每個數據分析師面臨的挑戰。Excel的條件格式功能通過自動化的視覺標記&#xff0c;幫助用戶輕松應對這一難題。 本文將詳細介紹條件格式的應用場景&am…

【HarmonyOS Next之旅】DevEco Studio使用指南(十一)

目錄 1 -> 代碼實時檢查 2 -> 代碼快速修復 3 -> C快速修復使用演示 3.1 -> 填充switch語句 3.2 -> 使用auto替換類型 3.3 -> 用&#xff1f;&#xff1a;三元操作符替換if-else 3.4 -> 從使用處生成構造函數 3.5 -> 將變量拆分為聲明和賦值 1…

win10離線環境下配置wsl2和vscode遠程開發環境

win10離線環境下配置wsl2和vscode遠程開發環境 環境文件準備wsl文件準備vscode文件準備 內網環境部署wsl環境部署vscode環境部署 遷移后Ubuntu中的程序無法啟動 環境 內網機&#xff1a;win10、wsl1 文件準備 wsl文件準備 在外網機上的wsl安裝Ubuntu24.04&#xff0c;直接在…

Elasticsearch | ES索引模板、索引和索引別名的創建與管理

關注&#xff1a;CodingTechWork 引言 在使用 Elasticsearch (ES) 和 Kibana 構建數據存儲和分析系統時&#xff0c;索引模板、索引和索引別名的管理是關鍵步驟。本文將詳細介紹如何通過 RESTful API 和 Kibana Dev Tools 創建索引模板、索引以及索引別名&#xff0c;并提供具…

提高MCU的效率方法

要提高MCU(微控制器單元)的編程效率,需要從硬件特性、代碼優化、算法選擇、資源管理等多方面入手。以下是一些關鍵策略: 1. 硬件相關優化 時鐘與頻率: 根據需求選擇合適的時鐘源(內部/外部振蕩器),避免過高的時鐘頻率導致功耗浪費。關閉未使用的外設時鐘(如定時器、UA…

Visual Studio未能加載相應的Package包彈窗報錯

環境介紹&#xff1a; visulal studio 2019 問題描述&#xff1a; 起因&#xff1a;安裝vs擴展插件后&#xff0c;重新打開Visual Studio&#xff0c;報了一些列如下的彈窗錯誤&#xff0c;即使選擇不繼續顯示該錯誤&#xff0c;再次打開后任然報錯&#xff1b; 解決思路&am…

Android中Jetpack設計理念、核心組件 和 實際價值

一、Jetpack 的定義與定位&#xff08;基礎必答&#xff09; Jetpack 是 Google 推出的 Android 開發組件集合&#xff0c;旨在&#xff1a; 加速開發&#xff1a;提供標準化、開箱即用的組件 消除樣板代碼&#xff1a;解決傳統開發中的重復勞動問題 兼容性保障&#xff1a;…

計算機網絡 實驗二 VLAN 的配置與應用

一、實驗目的 1. 熟悉 VLAN 和 PORT VLAN 的原理&#xff1b; 2. 熟悉華為網絡模擬器的使用&#xff1b; 3. 掌握網絡拓撲圖的繪制&#xff1b; 4. 掌握單交換機內 VLAN 的配置。 二、實驗設備 PC、華為模擬器 ENSP。 三、實驗步驟 知識準備&#xff1a;VLAN 和 PORT V…

聊透多線程編程-線程基礎-3.C# Thread 如何從非UI線程直接更新UI元素

目錄 1. 使用 Control.Invoke 或 Control.BeginInvoke&#xff08;Windows Forms&#xff09; 2. 使用 Dispatcher.Invoke 或 Dispatcher.BeginInvoke&#xff08;WPF&#xff09; 3. 使用 SynchronizationContext 桌面應用程序&#xff08;如 Windows Forms 或 WPF&#xf…

TCP 和 UDP 可以使用同一個端口嗎?

TCP 和 UDP 可以使用同一個端口嗎&#xff1f; 前言 在深入探討 TCP 和 UDP 是否可以使用同一個端口之前&#xff0c;我們首先需要理解網絡通信的基本原理。網絡通信是一個復雜的過程&#xff0c;涉及到多個層次的協議和機制。在 OSI 模型中&#xff0c;傳輸層是負責端到端數…

RVOS-2.基于NS16550a ,為os添加終端交互功能。

2.1 實驗目的 為os添加uart功能&#xff0c;通過串口實現開發板與PC交互。 2.1 硬件信息 QEMU虛擬SoC含有 虛擬NS16550A設備 。 不同的地址線組合&#xff08;A2、A1、A0&#xff09;對應的讀寫模式和寄存器如下所示&#xff1a; 2.2 NS16550a 的初始化 線路控制寄存器&#…

java導入excel更新設備經緯度度數或者度分秒

文章目錄 一、背景介紹二、頁面效果三、代碼0.pom.xml1.ImportDevice.vue2.ImportDeviceError.vue3.system.js4.DeviceManageControl5.DeviceManageUserControl6.Repeater7.FileUtils8.ResponseModel9.EnumLongitudeLatitude10.詞條 四、注意點本人其他相關文章鏈接 一、背景介…

【力扣hot100題】(080)爬樓梯

讓我們掌聲恭迎動態規劃的始祖—— 最基礎的動態規劃&#xff0c;原始方法是維護一個數組&#xff0c;每次記錄到該階梯的方案數量&#xff0c;每次的數量是到上一個階梯的方案數量加上到上上一階梯的方案數量&#xff0c;因為只有兩種走法。 進階可以優化空間復雜度&#xf…

CVE-2025-24813 漏洞全解析|Apache Tomcat 關鍵路徑繞過與RCE

CVE-2025-24813 漏洞全解析&#xff5c;Apache Tomcat 關鍵路徑繞過與RCE 作者:Factor .Poc作者:iSee857 CVE-2025-24813 漏洞全解析&#xff5c;Apache Tomcat 關鍵路徑繞過與RCE一、漏洞概述二、影響版本三、漏洞原理&#x1f3af; 利用流程&#xff08;兩步&#xff09;&am…

初識Linux:常見指令與權限的理解,以及相關衍生知識

目錄 前言 關于linux的簡介 代碼開源 網絡功能強大 系統工具鏈完整 一、Linux下的基本指令 1.ls指令 2.pwd指令 3.cd指令 4.whoami指令 5.touch指令 6.mkdir指令 7.rm指令 8.man指令 9.cp指令 10.mv指令 11.nano指令 12.cat指令 13.tac指令 14.more指令 15.less指令 16.head指令…

JVM虛擬機篇(七):JVM垃圾回收器全面解析與G1深度探秘及四種引用詳解

JVM垃圾回收器全面解析與G1深度探秘及四種引用詳解 JVM虛擬機&#xff08;七&#xff09;&#xff1a;JVM垃圾回收器全面解析與G1深度探秘及四種引用詳解一、JVM有哪些垃圾回收器1. Serial回收器2. ParNew回收器3. Parallel Scavenge回收器4. Serial Old回收器5. Parallel Old回…