react組件傳值的四種方法
1、父向子傳值
父組件
classAppextendsReact.Component{
state={
name:'jack',
age:19,
gender:'男',
count:1
}
render() {
return<div >
御劍乘風(fēng)來(lái),除魔天地間!
<Child {...this.state} hobby={[1,2,3,4]}></Child>
</div>
}子組件:
const Child = (props) => {
console.log(props,99);
return<div>
御劍乘風(fēng)來(lái),除魔天地間!===Child======{props.count}
</div>
};2、子向父?jìng)髦?/h2>
父組件
classAppextendsReact.Component{
state={
name:'jack',
age:19,
gender:'男',
count:1
}
handle2=(msg)=>{
console.log(msg,77); // 123
}
render() {
return<div >
御劍乘風(fēng)來(lái),除魔天地間!==
<ChildgetMsg={this.handle2}></Child>
</div>
}子組件:
const Child = (props) => {
console.log(props,99);
var handle=()=>{
console.log(111);
props.getMsg('123')
}
return<div>
御劍乘風(fēng)來(lái),除魔天地間!===Child======
<buttononClick={handle}>child1</button></div>
};3、非父子傳值
child1 向 child2 傳值
思路:child 傳到app ,然后app傳到child2
classAppextendsReact.Component{
state={
name:'jack',
age:19,
gender:'男',
count:1
}
handle2=(msg)=>{
console.log(msg,77); // 123this.setState({
count:this.state.count+msg
})
}
render() {
return<div >
御劍乘風(fēng)來(lái),除魔天地間!==
<ChildgetMsg={this.handle2} ></Child>
<Child2count={this.state.count}></Child2>
</div>
}子組件1:
const Child = (props) => {
console.log(props,99);
var handle=()=>{
console.log(111);
props.getMsg('123')
}
return<div>
御劍乘風(fēng)來(lái),除魔天地間!===Child======
<buttononClick={handle}>child1</button></div>
};
const Child2 = (props) => {
console.log(props,99);
var handle=()=>{
console.log(111);
props.getMsg('123')
}
return<div>
御劍乘風(fēng)來(lái),除魔天地間!===Child======
<buttononClick={handle}>child1</button></div>
};4、Context 方法 傳值 【類(lèi)似vue的 provide / inject】
步驟:
1- const {Provider,Consumer} = React.createContext()
2- Provider包裹父組件 定義value是需要傳的值 ====<Provider value={this.state.count}>
3- Consumer包裹需要接收數(shù)據(jù)的組件 data接收數(shù)據(jù)
<Consumer >
{data=>(
<div>
御劍乘風(fēng)來(lái),除魔天地間! ==Child2*****{data}
</div>
)}代碼如下:
import React from 'react'const {Provider,Consumer} = React.createContext()
const Child = (props) => {
console.log(props,99);
return <div>
御劍乘風(fēng)來(lái),除魔天地間!===Child
</div>
};
classChild2extendsReact.Component{
render() {
return <div>
<Consumer >
{data=>(
<div>
御劍乘風(fēng)來(lái),除魔天地間! ==Child2*****{data}
</div>
)}
</Consumer>
</div>
}
}
classAppextendsReact.Component{
state={
name:'jack',
age:19,
gender:'男',
count:1
}
render() {
return <Provider value={this.state.count}>
御劍乘風(fēng)來(lái),除魔天地間!=={this.state.name}
<Child></Child>
<Child2></Child2>
</Provider>
}
}
export default App到此這篇關(guān)于react組件傳值的四種方法的文章就介紹到這了,更多相關(guān)react組件傳值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
從零開(kāi)始最小實(shí)現(xiàn)react服務(wù)器渲染詳解
這篇文章主要介紹了從零開(kāi)始最小實(shí)現(xiàn)react服務(wù)器渲染詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
React Native提供自動(dòng)完成的下拉菜單的方法示例
這篇文章主要為大家介紹了React Native提供自動(dòng)完成的下拉菜單的方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
可定制react18 input otp 一次性密碼輸入組件
這篇文章主要為大家介紹了可定制react18 input otp 一次性密碼輸入組件,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
聊聊jenkins部署vue/react項(xiàng)目的問(wèn)題
本文給大家介紹了jenkins部署vue/react項(xiàng)目的問(wèn)題,文末給大家提到了centOS安裝jenkins的腳本,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2022-02-02
React中的setState使用細(xì)節(jié)和原理解析(最新推薦)
這篇文章主要介紹了React中的setState使用細(xì)節(jié)和原理解析(最新推薦),前面我們有使用過(guò)setState的基本使用, 接下來(lái)我們對(duì)setState使用進(jìn)行詳細(xì)的介紹,需要的朋友可以參考下2022-12-12
react-native 配置@符號(hào)絕對(duì)路徑配置和絕對(duì)路徑?jīng)]有提示的問(wèn)題
本文主要介紹了react-native 配置@符號(hào)絕對(duì)路徑配置和絕對(duì)路徑?jīng)]有提示的問(wèn)題,文中通過(guò)圖文示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-01-01

