React如何实现父子组件通信

本文介绍了在React中如何实现在父组件显示数值,并通过子组件的按钮点击修改父组件的值。主要步骤包括:在父组件定义修改值的函数,然后通过props将该函数传递给子组件,子组件接收到函数后即可调用,从而达到父子组件间的通信效果。
摘要由CSDN通过智能技术生成

一、场景

在父组件显示数值,在子组件有个按钮点击后修改父组件的值。

二、代码

HTML

<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport"
        content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script src="https://cdn.bootcdn.net/ajax/libs/react/17.0.0-rc.0/umd/react.production.min.js"></script>
  <script src="https://cdn.bootcdn.net/ajax/libs/react-dom/0.0.0-0c756fb-f7f79fd/umd/react-dom.production.min.js"></script>
</head>
<body>
<div id="root"></div>
</body>
</html>

CSS

.father {
    background: #000;
}
.son {
    background: #333;
}

JSX

function App(){
  return (
    <div>
      <Father/>
    </div>
  )
}

class Father extends React.Component{
  constructor(){
    super()
    this.state = {
      number: 0
    }
  }
  changeValue(){
    this.setState({
      number: this.state.number + 1
    })
  }
  render(){
    return (
      <div className="father">
        <div>{this.state.number}</div>
        <Son change={this.changeValue.bind(this)}/>
      </div>
    )
  }
}

class Son extends React.Component {
  constructor(){
    super()
  }
  render(){
    return (
      <div className="son">
        <button onClick={this.props.change}>更改值</button>
      </div>
    )
  }
}

render()

function render(){
  ReactDOM.render(<App/>, document.querySelector('#root'))
}

三、结论

在父组件声明一个函数,用于修改父组件中的值。
将此函数通过子组件的props进行传参

<Son change={this.changeValue.bind(this)}>

子组件接收后,即可调用外部函数

<button onClick={this.props.change}>更改值</button>

四、代码效果预览

预览链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值