我可以在trigger()中触发多事件或在JQuery中链接它们吗?例如:
$(element).trigger('event1 event2 event3');
Run Code Online (Sandbox Code Playgroud)
要么
$(element).trigger('event1').trigger('event2');
Run Code Online (Sandbox Code Playgroud)
要么
$(element).trigger('event1');
$(element).trigger('event2');
Run Code Online (Sandbox Code Playgroud)
正如其他答案所述,最好的内置方法是:
$(element).trigger('event1').trigger('event2');
Run Code Online (Sandbox Code Playgroud)
但是,我发现如果你在这个地方做这个,一个简单的插件可以很好地清理它,允许空格分隔的语法(就像其他 jQuery 方法一样).这是一个这样一个插件的快速示例:
$.fn.triggerAll = function(events) {
if(!events) return this; //don't blow up if .triggerAll() without params
var self = this; //keep a reference
$.each(events.split(" "), function(i, e) { self.trigger(e); });
return this;
};
Run Code Online (Sandbox Code Playgroud)
然后你可以用空格分隔的事件名称来调用它,如下所示:
$(element).triggerAll('event1 event2 event3');
Run Code Online (Sandbox Code Playgroud)