我一直在玩jQuery的Events方法,我使用以下代码构建了一个简单的事件总线:
$(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'});
我的问题是,使用“窗口”管理事件有什么问题吗?
答案 0 :(得分:7)
是的,这是在DOM冒泡的上下文之外使用自定义jQuery事件的强大功能的好方法。但它也可以通过使用空对象{}
而不是窗口来更有效地完成(不需要查询DOM,因为它的性能代价高且与我认为的 的要求无关)。
Ben Alman写了一个很棒的jQuery plugin用于以这种方式管理事件,避开一些不相关的jQuery事件元素,同时使用相同的原则来实现轻量级Publish / Subscribe pattern(监听和触发)由字符串定义的事件,其间传递可选的额外任意数据。)