網站首頁 編程語言 正文
組件間的關系
- 父子組件
- 兄弟組件
- 祖孫組件
通信方式
- 通過 props 方式傳遞數據。
- Context 方式(一般用于祖孫組件通信)。
- 集中式狀態管理 Redux(一般用于很多組件間都要共享數據的情況下)。
父子組件通信
父子組件通信一般通過 props 方式傳遞數據。
父組件向子組件傳遞數據:
父組件通過向子組件傳遞 props,子組件得到 props 后進行相應的處理。
// Parent.js
import React, { Component } from "react";
import Child from "./Child.js";
export default class Parent extends Component{
render(){
return(
<div>
// 父組件通過 props 向子組件傳遞參數
<Child title = "父組件向子組件通信" />
</div>
)
}
}
// Child.js
import React,{ Component } from "react";
export default class Child extends Component{
render(){
return(
// 子組件通過 this.props 接收父組件傳遞過來的參數
<div>{this.props.title}</div>
)
}
}
子組件主動觸發父組件方法,向父組件傳遞數據:
父組件將一個函數作為 props 傳遞給子組件,子組件調用該函數,便可以向父組件通信。
// Parent.js
import React,{ Component } from "react";
import Child from "./Child.js";
export default class Parent extends Component{
handleChange(val){
console.log(val) // 我是子組件傳給父組件的值
}
render(){
return(
<div>
// 父組件通過 props 把方法傳遞給子組件
<Child handleChange={this.handleChange} />
</div>
)
}
}
// Child.js
import React,{ Component } from "react";
export default class Child extends Component{
handleClick(){
// 子組件接收并調用父組件傳遞過來的方法
this.props.handleChange(‘我是子組件傳給父組件的值')
}
render(){
return(
<button onClick={this.handleClick}>按鈕</button>
)
}
}
父組件主動觸發子組件方法,獲取子組件數據:
// Parent.js
import React,{ Component } from "react";
import Child from "./Child.js";
export default class Parent extends Component{
childRef = React.createRef()
handleClick(val){
//父組件觸發子組件方法
this.childRef.current.handleChange()
}
render(){
return(
<div onClick={this.handleClick}>
// 父組件通過 props 把方法傳遞給子組件
<Child ref={this.childRef} />
</div>
)
}
}
// Child.js
import React,{ Component } from "react";
export default class Child extends Component{
handleChange(){
// 子組件執行邏輯操作
...
// 子組件返回數據,傳遞給父組件
// return {}
}
render(){
return(
<button onClick={this.handleChange}>按鈕</button>
)
}
}
原文鏈接:https://blog.csdn.net/wsln_123456/article/details/109157645
相關推薦
- 2023-07-24 uniapp開發小程序,包過大解決方案
- 2022-04-01 k8s Error: could not find tiller
- 2022-10-11 Systemtap BPF/BCC bpftrace 實踐對比
- 2022-08-15 ArrayList和LinkedList和Vector的區別
- 2022-07-14 Django項目配置連接多個數據庫的方法記錄_python
- 2022-05-15 Python學習之異常處理詳解_python
- 2022-08-03 Django框架中模型的用法_python
- 2022-05-22 C#多線程編程Task用法詳解_C#教程
- 最近更新
-
- 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同步修改后的遠程分支