js实现一个EventEmitter类的完整写法

本文将详细介绍如何在JavaScript中实现一个EventEmitter类,包括使用on方法为对象绑定事件和事件处理函数。参考链接提供了一个详细的实现示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

js实现一个EventEmitter类的完整写法

// 实现一个EventEmitter类作为被观察的对象
class EventEmitter {
    constructor() {
        this.listeners = new Map();
    }

    addListener(label, callback) {
        this.listeners.has(label) || this.listeners.set(label, []);
        this.listeners.get(label).push(callback);
    }
    removeListener(label, callback) {
        let listeners = this.listeners.get(label);
        let index;
        if (listeners && listeners.length) {
            index = listeners.reduce((i, listener, index) => {
                return (isFunction(listener) && listener === callback) ? i = index : i;
            }, -1);
        }
        if (index > -1) {

            listeners.splice(index, 1);
            this.listeners.set(label, listeners);
            return true;
        }

        return false;
    }
    emit(label, ...args) {
        let listeners = this.listeners.get(label);
        if (listeners && listeners.length) {
            listeners.forEach((listener) => {
                listener(...args);
            })
            return true;
        }

        return false;
    }
}
// 实现一个观察者
class Observer {
    constructor(id, subject) {
        this.id = id;
        this.subject = subject;
    }
    on(label, callback) {
        this.subject.addListener(label, callback);
    }
}

通过on给被观察者对象绑定事件以及事件处理函数:

let observable = new EventEmitter();

let [observer1, observer2] = [
    new Observer(1, observable),
    new Observer(2, observable)
]

observer1.on('change', (data) => {
    console.log(`${observer1.id} observered data:`, data);
})

observer2.on('haha', (data) => {
    console.log(`${observer2.id} observered data:`, data);
})

observable.emit('change', {a: 1}); // 1 observered data: { a: 1 }
observable.emit('haha', [1, 2, 3]); // 2 observered data: [ 1, 2, 3 ]

参考:https://blog.csdn.net/bdss58/article/details/51473107

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力不熬夜的小喵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值