非常好理解的js原生发布订阅模式

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>

<body>

</body>
<script>
    function Public() {
        this.handlers = {};
    }
    Public.prototype = {
        // 订阅事件
        on(name, fn) {
            let that = this;
            if (!(name in that.handlers)) {
                that.handlers[name] = [];
            }
            that.handlers[name].push(fn);
            return this;
        },
        // 触发事件(发布事件)
        emit(name) {
            let that = this;
            let item = Array.prototype.slice.call(arguments, 1);
            for (let i = 0; i < that.handlers[name].length; i++) {
                that.handlers[name][i].a    pply(that, item);
            }
            return that;
        },
        // 删除订阅事件
        off(name, fn) {
            let currentEvent = this.handlers[name];
            let len = 0;
            if (currentEvent) {
                len = currentEvent.length;
                for (let i = len - 1; i >= 0; i--) {
                    if (currentEvent[i] === fn) {
                        currentEvent.splice(i, 1);
                    }
                }
            }
            return this;
        }
    };

    var Publisher = new Public();

    //订阅事件a
    Publisher.on('a', function (data) {
        console.log(1 + data);
    });
    Publisher.on('a', function (data) {
        console.log(2 + data);
    });

    //触发事件a
    Publisher.emit('a', '我是第1次调用的参数');

    // Publisher.emit('a', '我是第2次调用的参数');
</script>

</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值