发布订阅模式

import React from "react";

// 发布订阅
const login = {
    list: {},
    // 发布
    publish(key) {
        console.log('a', this.list[key]);
        this.list[key].map(dt => {
            dt()
        })
    },
    // 订阅
    ding(key, value) {
        if (!this.list[key]) {
            this.list[key] = []
        }
        this.list[key].push(value)
    }
}

// 张波
function Xx() {
    function abc() {
        console.log('abc');
    }
    function xxx() {
        console.log('xxx');
    }
    // 订阅
    login.ding('pt', abc)
    login.ding('pt', xxx)
}

Xx()
export default function Issue(props) {

    const zhang = () => {
        // 发布
        login.publish('pt')
    }
    return (
        <div>
            <button onClick={zhang}>发布</button>
        </div>
    )
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值