一个非常简单的seajs事件分发模块

本文介绍了一个简单的事件分发模块实现,该模块可通过$on监听事件并使用$emit触发事件,适用于解决模块间的通信问题。

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

刚看了一下seajs,突发奇想写一个事件的分发模块,可以方便的进行事件的播放已经监听,可偷懒的解决循环依赖或者较为麻烦的不同模块的controller之间的通信:

define(function (require, exports, module) {

    function EventEmitter() {
        var self = this;

        if (!self.hasOwnProperty('events')) {
            Object.defineProperty(self, 'events', {
                value: {},
                writable: false
            });
        }

        if (!self.hasOwnProperty('$on')) {
            Object.defineProperty(self, '$on', {
                value: function (name, cb) {
                    if (typeof name == 'string' && typeof cb == 'function') {
                        if (!self.events.hasOwnProperty(name)) {
                            Object.defineProperty(self.events, name, {
                                value: [],
                                writable: false
                            });
                        }
                        if (self.events[name].indexOf(cb) < 0) {
                            self.events[name].push(cb);
                        }
                    }
                },
                writable: false
            });
        }

        if (!self.hasOwnProperty('$emit')) {
            Object.defineProperty(self, '$emit', {
                value: function (name, data) {
                    if (typeof name == 'string' && self.events.hasOwnProperty(name)) {
                        self.events[name].forEach(function (func) {
                            if (typeof func == 'function') {
                                func(data);
                            }
                        });
                    }
                },
                writable: false
            });
        }
    }

    module.exports = new EventEmitter();

});


代码非常简单,功能也非常简单,通过$on来监听事件,注册监听函数,通过$emit来发送事件消息,没有做其他的例如阻止冒泡之类的操作,仅供交流。

onfire.js 是一个很简单的事件分发的Javascript库(仅仅 0.9kb),简洁实用。 可以用于: 简单的事件分发; 在 react / vue.js / angular 用于跨组件的轻量级实现; 事件订阅和发布; API方法: 1.on(event_name, callback) 绑定事件,参数为event_name和callback, 当有名字为event_name的事件发生的时候,callback方法将会被执行。 这个方法会返回一个eventObj,这个可以用于使用un(eventObj)方法来取消事件绑定。 2.one(event_name, callback) 绑定(订阅)事件,参数为 event_name with callback. 当被触发一次之后失效。只能被触发一次,一次之后自动失效。 3.fire(event_name, data) 触发名字为event_name的事件,并且赋予变量data为callback方法的输入值。 4.un(eventObj / eventName / function) 取消事件绑定。可以仅仅取消绑定一个事件回调方法,也可以直接取消全部的事件; 5.clear() 清空所有事件。 使用Demo: 1. 引入js文件 npm install onfire.js 可以使用[removed]标签直接引入; 也可以使用require或者import关键字引入,会得到全局变量 onfire。 import onfire from 'onfire.js'; // or var onfire = require("onfire.js"); 2. 简单使用 使用方法on来订阅事件, 使用un来取消订阅, 使用fire方法来触发事件。 import onfire from 'onfire.js'; // 绑定事件 var eventObj = onfire.on('test_event', function(data) {     console.log('this is a event 1'); }); var eventObj2 = onfire.on('test_event', function(data) {     console.log('this is a event 2'); }); // 触发事件 onfire.fire('test_event', 'test_data'); // 取消绑定 onfire.un(eventObj); // 取消绑定这个事件. onfire.un('test_event'); // 取消绑定所有的 `test_event`. 标签:onfire
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值