触发多事件

qin*_*ang 2 jquery triggers

我可以在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)

Nic*_*ver 6

正如其他答案所述,最好的内置方法是:

$(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)

你可以在这里测试一下