網站首頁 編程語言 正文
1. 隔代組件傳值
1.1 props傳遞
傳遞方式:通過props屬性自上而下逐層傳遞
存在問題:層級過多導致傳值繁瑣
import React from 'react'
//父組件
class App extends React.Component{
render(){
return (
//1.傳遞value值
<Demo1 value="hello hello"/>
)
}
}
//中間組件
class Demo1 extends React.Component{
render(){
return (
//2.中間組件幫助傳遞value值
<Demo2 value={this.props.value} />
)
}
}
//子組件
class Demo2 extends React.Component{
render(){
return (
//3.接收value值
<h1>{this.props.value}</h1>
)
}
}
export default App
1.2 Context傳遞
傳遞方式:類似于全局變量
存在問題:組件復用性較差
使用方法:
- 創建Context(ValueContext可任意命名)
const ValueContext = React.createContext('') //默認值為''
- 用ValueContext.Provider包裹組件樹中的根節點,并傳遞
value
值<ValueContext.Provider value="hello hello">
- 此時,該組件樹中的節點均能訪問到步驟2中根節點所傳遞的
value
值
3.1 指定contextType讀取當前的ValueContextstatic contextType = ValueContext
3.2 讀取value值this.context
import React from 'react'
//1.創建一個Context
const ValueContext = React.createContext('') //默認值為''
//父組件
class App extends React.Component{
render(){
return (
//2.用ValueContext.Provider包裹組件樹中的根節點
//傳遞value值為"hello hello"
//組件樹中的節點均能訪問到該value值
<ValueContext.Provider value="hello hello">
<Demo1/>
</ValueContext.Provider>
)
}
}
//中間組件
class Demo1 extends React.Component{
//指定contextType讀取當前的ValueContext
static contextType = ValueContext
render(){
return (
//this.context即父組件中傳遞的"hello hello"
<div>
<h1>{this.context}</h1>
<Demo2/>
</div>
)
}
}
//子組件
class Demo2 extends React.Component{
//指定contextType讀取當前的ValueContext
static contextType = ValueContext
render(){
return (
//this.context即父組件中傳遞的"hello hello"
<h2>{this.context}</h2>
)
}
}
export default App
效果圖:
原文鏈接:https://blog.csdn.net/SmallPig_Code/article/details/125708042
相關推薦
- 2022-11-18 詳解C語言內核字符串拷貝與比較_C 語言
- 2022-10-08 PostgreSQL12.5中分區表的一些操作實例_PostgreSQL
- 2022-08-14 協同開發巧用gitignore中間件避免網絡請求攜帶登錄信息_Golang
- 2022-07-25 C++細講深淺拷貝與初始化列表如何操作_C 語言
- 2022-11-12 C++中的數組、鏈表與哈希表_C 語言
- 2022-06-08 nacos項目啟動報錯:Connection refused: no further informa
- 2022-10-02 Opencv檢測多個圓形(霍夫圓檢測,輪廓面積篩選)_C 語言
- 2022-11-22 在?React?項目中全量使用?Hooks的方法_React
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支