我有的:
$('#main').find('*').on('click.stop', function() {return false;});
我想要什么:由于性能问题而将选择'*'
器
更改为。all classes with a bound click_handler
我的想法:在将处理程序绑定到类时分配其他类。
想法问题:我必须更改的代码量太高了!而且我很懒...
我有的:
$('#main').find('*').on('click.stop', function() {return false;});
我想要什么:由于性能问题而将选择'*'
器
更改为。all classes with a bound click_handler
我的想法:在将处理程序绑定到类时分配其他类。
想法问题:我必须更改的代码量太高了!而且我很懒...
您可以使用这样的 clickhandler 选择所有元素:
var e = $.data($(body).get(0), 'events').click;
如果你这样做了,你可以使用 $.each 循环遍历这些元素并将你的函数/事件应用到它们:)
你可以写你的表达式来做到这一点。jQuery 本身不支持此选择器。
jQuery.extend(jQuery.expr[':'], {
click: function(elem) {
return $(elem).hasEvent('click');
}
});
然后,您可以使用:
$("*:click").on('click.stop',...
有事件:
$.fn.hasEvent = function(event, fn) {
if (!event) { return this; }
var has = {
event: false,
namespace: false,
handler: false
},
events = this.data("events"),
namespace = event.split(".");
event = namespace.shift();
namespace = namespace.join(".");
if (events) {
if (!namespace) { has.namespace = true; }
if (!fn) { has.handler = true; }
if (event in events) {
$.each(events[event], function(i, v) {
if (namespace) {
if (namespace === v.namespace && event === v.type) {
has.namespace = true;
has.event = true;
if (fn && fn === v.handler) { has.handler = true; }
}
}
else {
if (event === v.type) {
has.event = true;
if (fn && fn === v.handler) { has.handler = true; }
}
}
});
}
}
return has.event && has.namespace && has.handler;
};
对此的答案可能会对您有所帮助。这个问题是检查元素上是否存在事件。