7

我一直在使用 jQuery 的事件方法,并使用以下代码构建了一个简单的事件总线:

$(window).on('test:event', function (event, data) {
    console.log('Saw a test event: event=%o, data=%o', event, data);
});

$(window).trigger('test:event', {test_data: 'foo'});

我的问题是,使用“窗口”管理事件有什么问题吗?

4

1 回答 1

11

是的,这是在 DOM 冒泡上下文之外使用自定义 jQuery 事件的强大功能的好方法。但它也可以通过使用空对象而不是窗口来更有效地完成(无需查询 DOM,因为这会提高性能并且与我假设的要求无关)。{}

Ben Alman编写了一个很棒的jQuery 插件,用于以这种方式管理事件,它避开了一些不相关的 jQuery 事件元素,同时使用相同的原理来实现轻量级的发布/订阅模式(侦听和触发由字符串定义的事件,以及可选的额外任意数据之间通过)。

于 2013-02-21T17:25:19.140 回答