React組件通信實(shí)現(xiàn)流程詳解
組件間的關(guān)系
- 父子組件
- 兄弟組件
- 祖孫組件
通信方式
- 通過 props 方式傳遞數(shù)據(jù)。
- Context 方式(一般用于祖孫組件通信)。
- 集中式狀態(tài)管理 Redux(一般用于很多組件間都要共享數(shù)據(jù)的情況下)。
父子組件通信
父子組件通信一般通過 props 方式傳遞數(shù)據(jù)。
父組件向子組件傳遞數(shù)據(jù):
父組件通過向子組件傳遞 props,子組件得到 props 后進(jìn)行相應(yīng)的處理。
// Parent.js
import React, { Component } from "react";
import Child from "./Child.js";
export default class Parent extends Component{
render(){
return(
<div>
// 父組件通過 props 向子組件傳遞參數(shù)
<Child title = "父組件向子組件通信" />
</div>
)
}
}
// Child.js
import React,{ Component } from "react";
export default class Child extends Component{
render(){
return(
// 子組件通過 this.props 接收父組件傳遞過來的參數(shù)
<div>{this.props.title}</div>
)
}
}子組件主動(dòng)觸發(fā)父組件方法,向父組件傳遞數(shù)據(jù):
父組件將一個(gè)函數(shù)作為 props 傳遞給子組件,子組件調(diào)用該函數(shù),便可以向父組件通信。
// 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(){
// 子組件接收并調(diào)用父組件傳遞過來的方法
this.props.handleChange(‘我是子組件傳給父組件的值')
}
render(){
return(
<button onClick={this.handleClick}>按鈕</button>
)
}
}
父組件主動(dòng)觸發(fā)子組件方法,獲取子組件數(shù)據(jù):
// Parent.js
import React,{ Component } from "react";
import Child from "./Child.js";
export default class Parent extends Component{
childRef = React.createRef()
handleClick(val){
//父組件觸發(fā)子組件方法
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(){
// 子組件執(zhí)行邏輯操作
...
// 子組件返回?cái)?shù)據(jù),傳遞給父組件
// return {}
}
render(){
return(
<button onClick={this.handleChange}>按鈕</button>
)
}
}
到此這篇關(guān)于React組件通信實(shí)現(xiàn)流程詳解的文章就介紹到這了,更多相關(guān)React組件通信內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在react中對(duì)less實(shí)現(xiàn)scoped配置方式
這篇文章主要介紹了在react中對(duì)less實(shí)現(xiàn)scoped配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
一文詳解ReactNative狀態(tài)管理redux-toolkit使用
這篇文章主要為大家介紹了ReactNative狀態(tài)管理redux-toolkit使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
react搭建在線編輯html的站點(diǎn)通過引入grapes實(shí)現(xiàn)在線拖拉拽編輯html
Grapes插件是一種用于Web開發(fā)的開源工具,可以幫助用戶快速創(chuàng)建動(dòng)態(tài)和交互式的網(wǎng)頁元素,它還支持多語言和多瀏覽器,適合開發(fā)響應(yīng)式網(wǎng)頁和移動(dòng)應(yīng)用程序,這篇文章主要介紹了react搭建在線編輯html的站點(diǎn)通過引入grapes實(shí)現(xiàn)在線拖拉拽編輯html,需要的朋友可以參考下2023-08-08
React Native 真機(jī)斷點(diǎn)調(diào)試+跨域資源加載出錯(cuò)問題的解決方法
下面小編就為大家分享一篇React Native 真機(jī)斷點(diǎn)調(diào)試+跨域資源加載出錯(cuò)問題的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-01-01
在React中使用React.createRef:更優(yōu)雅的DOM引用方式
React提供了多種方式來引用DOM元素,其中React.createRef()是一種更為現(xiàn)代、更優(yōu)雅的方式,在這篇文章中,我們將深入了解React.createRef()的應(yīng)用,以及它為開發(fā)者帶來的便利,感興趣的朋友一起看看吧2024-01-01

