zoukankan      html  css  js  c++  java
  • react组件间的通信父子通信,子父通信,兄弟通信

    react组件间的通信

    父子通信

    父组件可以将自己的状态通过属性的方式传递给子组件,然后子组件通过props获取到传递来的属性。

    father.js父组件中

    render() {
            let {list} =this.state;
            return (
                <div>
                    <List list={list}/>
                </div>
            )
        }

    son.js子组件中

    render() {
        //接收到父组件传过来的数据
            let {list} =this.props;
            return(
                <div>
                    {
                        list.map((item,index)=>{
                        return <li key={index}>{item}</li>
                        })
                    }
                </div>
            )
        }
    子父通信

    父组件可以将一个更改自身状态的方法传递给子组件,然后子组件通过props接受后进行调用,相当于父组件的方法被执行了,从而更改了自身的状态。

    父组件中想要获取到子组件input输入的数据

    父组件中的代码

    render() {
            let {list} =this.state;
            return (
                <div>
                    <Input add={this.add}/>
                </div>
            )
        }

    子组件中的代码

    //定义一个函数,当按下enter键时,调用子组件传递过来的add方法
    down=(e)=>{
            if(e.keyCode===13){
                this.props.add(e.target.value)
            }
    
        }
    
        render() {
            return (
                <div>
                    <input onKeyUp={this.down}/>
                </div>
            )
        }
    兄弟组件通信

    兄弟组件通信

    主要思想就是发布事件(on 监听)和订阅事件(trigger 触发)。

    创建event-Hub.js 在组件a和b中引入

    event-Hub.js

    let callbackLists = {}
    let eventHub = {
        trigger(eventName, data) {
            let callbackList = callbackLists[eventName]
            if (!callbackList) {
                return
            }
            for (let i = 0; i < callbackList.length; i++) {
                callbackList[i](data)
            }
        },
        on(eventName, callback) {
            if (!callbackLists[eventName]) {
                callbackLists[eventName] = []
            }
            callbackLists[eventName].push(callback)
        }
    }
    
    export default eventHub

    组件a中

    down=()=>{
            EventHub.trigger("bianse","yellow")
        }
        render() {
            return (
                <div>
                    <button onClick={this.down}>点击</button>
                </div>
            )
        }

    组件b中

    state={
            color:'red'
        }
        componentDidMount(){
            //接收子组件穿过类的颜色值
            EventHub.on("bianse",color=>{
                this.setState({
                    color
                })
            })
        }
        render() {
            return (
                <div>
                    <span style={{color:this.state.color}}>文本</span>
                </div>
            )
        }
    请用今天的努力,让明天没有遗憾。
  • 相关阅读:
    编程思想
    为什么静态成员、静态方法中不能用this和super关键字
    C#中静态与非静态方法比较
    数组,集合,列表的使用与区别
    2017-3-23 网络IP
    [精彩] 关于DB2的内存分配
    DB2 常用命令
    SQL0973N在 "<堆名>" 堆中没有足够的存储器可用来处理语句
    DB2通用数据库性能调整的常用方法
    创建DB2数据库联合对象
  • 原文地址:https://www.cnblogs.com/cupid10/p/15617675.html
Copyright © 2011-2022 走看看