手写发布订阅类

class Sub {
  events = {};

  on(type, func) {
    !Array.isArray(this.events[type]) ? (this.events[type] = []) : null;
    let arr = this.events[type];
    if (arr.includes(func)) return;
    arr.push(func);
  }

  off(type, func) {
    let arr = this.events[type];
    let item = null;
    if (!Array.isArray(this.events[type])) {
      throw new TypeError(`${type} 自定义事件在事件池中并不存在!`);
    }
    for (let i = 0; i < arr.length; i++) {
      item = arr[i];
      if (item === func) {
        // 这样只是让集合中当前项值变为null,但是集合的机构是不发生改变的「索引不变」;
        // 下一次执行emit的时候,遇到当前项是null,我们再去把其移除掉即可;
        arr[i] = null;
        break;
      }
    }
  }

  emit(type, ...params) {
    let arr = this.events[type];
    let item = null;
    for (let i = 0; i < arr.length; i++) {
      item = arr[i];
      if (typeof item === "function") {
        item(...params);
        continue;
      }
      //不是函数的值都移除掉即可
      arr.splice(i, 1);
      i--;
    }
  }
}

const sub = new Sub();

const fn1 = () => console.log(1);
const fn2 = () => console.log(2);
const fn3 = () => {
  console.log(3);
  sub.off("A", fn1);
  sub.off("A", fn2);
};
const fn4 = () => console.log(4);
const fn5 = () => console.log(5);
const fn6 = () => console.log(6);

sub.on("A", fn1);
// sub.on("A", fn1);
sub.on("A", fn2);
sub.on("A", fn3);
sub.on("A", fn4);
sub.on("A", fn5);
sub.on("A", fn6);
setTimeout(() => {
  sub.emit("A");
}, 1000);

setTimeout(() => {
  sub.emit("A");
}, 2000);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值