zoukankan      html  css  js  c++  java
  • React 借助pubsub-js进行兄弟组件的传递值

    1===》 raect中两个 兄弟组件  互相通信使用的技术
    使用 消息订阅(subscribe)和发布(publish)机制   s儿 伯 s rai b   pʌ b lɪ ʃ
    有一个库可以处理
    PubSubJS  它是第三方插件  
    1)下载 cnpm install pubsub-js -S    我的版本  "pubsub-js": "^1.7.0",
    2) 在需要使用的组件中引入    import PubSub from "pubsub-js" 
      // id 声明一个唯一的id,或者标识符,为pubsub-js提供辨识,千万不可重复
      // data 第二个参数也可以传递一个对象  它表示传递的内容
       PubSub.publish(id, data)   开始发布

       PubSub.subscribe(id, callback(message, data){}) 订阅

     
    Numbergo1 .js兄弟组件  可以向Numbergo2 .js组件传递值
    import React, { Component } from "react"
    import PubSub from "pubsub-js"
    
    export default class Numbergo1 extends Component {
        // 发送消息:PubSub.publish(名称, 参数)
    
        state={
            listitem:"我是从一个组件的 跑过来的"
        }
        
        chuandi=()=>{
            // PubSub.publish(id, data)  
            // id 声明一个唯一的id,或者标识符,为pubsub-js提供辨识,千万不可重复
            // data 第二个参数也可以传递一个对象
            let {listitem}=this.state //结果
            PubSub.publish('mykeyvalue',listitem)
     
        }
    
    
        render() {
            return (
                <div>
                    <button onClick={this.chuandi}>按钮</button>
                </div>
               
            )
        }
    }
    Numbergo2.js
    import React, { Component } from "react"
    import PubSub from "pubsub-js"
    
    
    export default class Numbergo2 extends Component {
        // 发送消息:PubSub.publish(名称, 参数)
        
        state={
            info:""
        }
    
    
        // 声明周期 组件完成挂载之后
        componentDidMount(){
            // mykeyvalue表示符  msg报错信息  data传递过来的数据
            PubSub.subscribe("mykeyvalue",(msg,data)=>{
                console.log("从另外一个组件从低过来的数据",data);
                this.setState({
                    info: data
                })
            })
        }
    
       
        render() {
            // render使用state中的数据 必须要先解构构
            let {info}=this.state
            return (
                <div>
                    ----{info}
                </div>
    
            )
        }
    }

     

  • 相关阅读:
    2020了,初/中级前端面试你应该知道的(上)
    Vue页面权限控制和动态添加路由
    Javascript获取数组中最大和最小值
    localStorage和cookie的跨域解决方案
    移动端常见问题汇总
    码云git本地仓库链接远程仓库
    IntelliJ IDEA Activation code亲测可用
    Sping4之注入参数
    Sping4之依赖注入
    Spring核心之IOC
  • 原文地址:https://www.cnblogs.com/IwishIcould/p/11621061.html
Copyright © 2011-2022 走看看