模拟发布/订阅数据传输方式

方案:  

        订阅消息时存储被订阅消息的消息名(后面作为对象键值)和函数回调,由于可以多次订阅同一个消息,所以以数组形式存储在对应的消息名中,在发布消息时,遍历消息对应的数据,触发函数并传参,实现数据的传递,另外防止内存泄漏,需要做取消订阅,在组件销毁前删除对象中存储对应数据.

设置一个类:

设置一个对象存储被订阅的键值和对应的函数回调

class Public {
    constructor() {
        // 初始化一个对象,用于存储被订阅的"键"和对应的"函数回调"
        this.publicList= {}
    }
}

订阅消息:

    publish(key, value) {
        if (this.publicList[key]) {
            this.publicList[key].forEach(back => {
                back(value)
            });
        }
    }

发布消息:

    subscribe(key, back) {
        if (this.publicList[key]) {
            this.publicList[key].push(back)
        } else {
            this.publicList[key] = [back]
        }
        return { key, back }
    }

取消订阅:

    // 取消订阅
    delBub({ key, back }) {
        if (this.publicList[key]) {
            this.publicList[key] = this.publicList[key].filter(item => {
                return item !== back
            })
        }
    }

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值