React父子事件传递方式

实现父子组件双向数据传递:

1,(父 ---> 子)父组件可以向子组件传递props,props中带有初始化子组件的数据,还有回调函数。

2,(子 ---> 父)子组件通过调用父组件传递到子组件的方法向父组件传递数据。

PS:更改props值是不能触发重新渲染的,只有调用setState才会触发控件的重新渲染,所以要实现React的父子组件之间的通讯,需要同时结合props与state来完成,eact是单向数据流,父组件可以向子组件传递props。

var Parent = React.createClass({
    getInitialState: function() {
        return {
            name: this.props.name
        }
    },
    onChangeName: function(name) {
        this.setState({name: name})
    },
    render: function() {
        return <div onMouseOver={this.onMouseOver} onMouseOut={this.onMouseOut}>
                    Hello&ensp;
                    <Child name={this.state.name} onChangeName={this.onChangeName}>
                    </Child>
                    ,&ensp;welcome.
                </div>;
    },
    onMouseOver: function() {
        this.setState({
            name: "Emily"
        });
    },
    onMouseOut: function() {
        this.setState({
            name: "Grace"
        });
    }
});
var Child = React.createClass({
    render: function() {
        return <span onClick={this.handleClick}>{this.props.name}</span>;
    },
    handleClick: function() {
        this.props.onChangeName("Chris");
    }
});
 
ReactDOM.render(
    <Parent name='Anna' />,
    document.getElementById('example')
);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值