我正在使用ez-checkbox插件,它只是将一个复选框包装到div中,因此复选框看起来更好。
<div class="ez-checkbox ez-checked">
<input type="checkbox" checked autocomplete="off" class="ezmark ez-hide ez-init">
</div>
所以我有很多这些,我想点击一下检查它们。从性能的角度来看,哪个点击处理程序是最好的:
首先 - 查找所有输入,过滤掉已经检查的输入,触发每个元素的点击事件,以便插件完成其工作。
oPhotos
.find('input')
.not(':checked')
.each(function() {
$(this).click();
});
第二 - 与第一次相同,但我们自己做“检查”工作。
oPhotos
.find('input')
.not(':checked')
.each(function() {
$(this)
.prop('checked', true)
.parent()
.addClass('ez-checked');
});
第三步 - 循环所有复选框,如果未选中当前 - 触发点击。
oPhotos
.find('input')
.each(function() {
if (! $(this).is(':checked')) $(this).click();
});
第四 - 循环所有复选框,如果未选中当前 - 请自行执行“检查”工作。
oPhotos
.find('input')
.each(function() {
if (! $(this).is(':checked')) {
$(this)
.prop('checked', true)
.parent()
.addClass('ez-checked');
}
});
答案 0 :(得分:2)
我已经performance tests了。事实证明,使用更复杂的选择器+使用.not()
+处理事件而不是触发它们来过滤项目是最快的选择。最糟糕的选择是循环所有元素以过滤它们并触发事件。