詳解react組件通訊方式(多種)
1、父組件向子組件傳值
父組件向子組件傳值一般采用props屬性傳遞
父組件:
import React from 'react'
import Child from './Child'
const dataList = [
{ id: '001', value: '張三' },
{ id: '002', value: '李四' }
]
const Parent = props => {
return (
<ul>
<Child dataList={dataList}></Child>
</ul>
)
}
export default Parent
子組件:
import React from 'react'
const Child = props => {
return (
<React.Fragment>
{
props.dataList.map(item => <li key={item.id}>{item.value}</li>)
}
</React.Fragment>
)
}
export default Child

2、子組件向父組件傳值
子組件調(diào)用父組件傳過來的回調(diào)函數(shù)來更改父組件的state
父組件
import React, { useState } from 'react'
import Child from './Child'
const Parent = props => {
const [count, setCount] = useState(0)
return (
<Child count={count} setCount={setCount}></Child>
)
}
export default Parent
子組件
import React from 'react'
const Child = props => {
return (
<React.Fragment>
<button onClick={() => {props.setCount(props.count-1)}}>-</button>
<span>{props.count}</span>
<button onClick={() => {props.setCount(props.count+1)}}>+</button>
</React.Fragment>
)
}
export default Child

3、跨級組件傳值(祖孫組件)
context是一個全局變量,像是一個大容器,在任何地方都可以訪問到,我們可以把要通信的信息放在context上,然后在其他組件中可以隨意取到;
但是React官方不建議使用大量context,盡管他可以減少逐層傳遞,但是當(dāng)組件結(jié)構(gòu)復(fù)雜的時候,我們并不知道context是從哪里傳過來的;而且context是一個全局變量,全局變量正是導(dǎo)致應(yīng)用走向混亂的罪魁禍?zhǔn)?
父組件
import React, { useState } from 'react'
import Child from './Child'
export const MyContext = React.createContext('hello')
const Parent = props => {
return (
<MyContext.Provider value="world">
<Child />
</MyContext.Provider>
)
}
export default Parent
子組件
import React from 'react'
import Son from './Son'
const Child = props => {
return (
<Son />
)
}
export default Child
孫組件
import React from 'react'
import { MyContext } from './Parent'
export default class Son extends React.Component {
render() {
return (
<MyContext.Consumer>
{
context => <div>{context}</div>
}
</MyContext.Consumer>
)
}
}

參考:
https://blog.csdn.net/xingfuzhijianxia/article/details/86151243
https://www.cnblogs.com/qinney1109/p/11202085.html
到此這篇關(guān)于詳解react組件通訊方式的文章就介紹到這了,更多相關(guān)react組件通訊內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react-navigation之動態(tài)修改title的內(nèi)容
這篇文章主要介紹了react-navigation之動態(tài)修改title的內(nèi)容,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09
React+Spring實現(xiàn)跨域問題的完美解決方法
這篇文章主要介紹了React+Spring實現(xiàn)跨域問題的完美解決方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-08-08
React學(xué)習(xí)之JSX與react事件實例分析
這篇文章主要介紹了React學(xué)習(xí)之JSX與react事件,結(jié)合實例形式分析了React中JSX表達(dá)式、屬性、嵌套與react事件相關(guān)使用技巧,需要的朋友可以參考下2020-01-01

