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