React?實現(xiàn)爺孫組件間相互通信
前言
最近在學習React,給大家總結下跨組件通信中,爺孫組件之間怎么相互通信。簡單明了上代碼直接一把梭,不多解釋。
爺孫組件間通信
案例如下:


代碼:
//跨組件通信
import React, { Component } from 'react'
//創(chuàng)建context 給初始值
const UserMessage = React.createContext({
nickName: 'yyy',
level: 1
})
export default class TextSingal extends Component {
constructor(props) {
super(props)
this.state = {
nickName: 'kkk',
level: 99,
name: 'ppp',
age: 9999
}
}
render() {
const { name, age } = this.state
return (
<div>
<h2>爺爺組件</h2>
<h3>name:{name}</h3>
<h3>age:{age}</h3>
{/* 改變數(shù)據(jù)孫組件也更新 */}
<button onClick={() => this.handelClick()}>updated</button>
{/* 傳入state對象和foo回調函數(shù) */}
{/* foo函數(shù)用于孫組件和爺組件通信 */}
<UserMessage.Provider value={{ ...this.state, foo: (name, age) => this.updateDatas(name, age) }}>
<Father />
</UserMessage.Provider>
</div>
)
}
handelClick() {
this.setState({
nickName: '虎威神',
level: 9999
})
}
updateDatas(name, age) {
this.setState({
name,
age
})
}
}
class Father extends Component {
render() {
return (
<div>
<h2>爸爸組件</h2>
<Son />
</div>
)
}
}
class Son extends Component {
render() {
// 解構
const { nickName, level, foo } = this.context
return (
<div>
<h2>兒子組件</h2>
<h3>nickname:{nickName}</h3>
<h3>level:{level}</h3>
{/* 下面兩種調用方式都可以 */}
{/* 改變爺組件的數(shù)據(jù) */}
<button onClick={() => this.handelClick()}>updated</button>
<button onClick={() => foo('牛霸天', 18)}>updated</button>
</div>
)
}
handelClick() {
this.context.foo('牛霸天', 18)
}
}
// 接受爺組件傳遞的值
Son.contextType = UserMessage爺給孫組件通信就不多說了,直接創(chuàng)建context傳入默認對象,然后在爺組件用該創(chuàng)建名創(chuàng)建對象包裹父組件,通過value傳值過去,然后在孫組件Son.contextType 進行接收,在this.context取值即可。


孫給爺傳值則是和子跟父傳值的道理一樣,通過傳入回調函數(shù)來進行修改。
到此這篇關于React 四線爺孫組件間相互通信的文章就介紹到這了,更多相關React組件通信內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
React?Hooks--useEffect代替常用生命周期函數(shù)方式
這篇文章主要介紹了React?Hooks--useEffect代替常用生命周期函數(shù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
react-pdf實現(xiàn)將pdf文件轉為圖片,用于頁面展示
這篇文章主要介紹了react-pdf實現(xiàn)將pdf文件轉為圖片,用于頁面展示問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
在React框架中實現(xiàn)一些AngularJS中ng指令的例子
這篇文章主要介紹了在JavaScript的React框架中實現(xiàn)一些AngularJS指令的例子,React使用Virtual DOM因而與普通的js框架有些不同,需要的朋友可以參考下2016-03-03

