16

我不确定是使用:first还是:eq(0)在选择器中。我很确定他们总是会返回同一个对象,但是一个比另一个更快吗?

我确信这里的某个人之前一定已经对这些选择器进行了基准测试,我不确定测试一个是否更快的最佳方法。

更新:这是我跑的板凳:

/* start bench */
for (var count = 0; count < 5; count++) {
    var i = 0, limit = 10000;
    var start, end;
    start = new Date();
    for (i = 0; i < limit; i++) {
        var $radeditor = $thisFrame.parents("div.RadEditor.Telerik:eq(0)");
    }
    end = new Date();
    alert("div.RadEditor.Telerik:eq(0) : " + (end-start));
    var start = new Date();
    for (i = 0; i < limit; i++) {
        var $radeditor = $thisFrame.parents("div.RadEditor.Telerik:first");
    }
    end = new Date();
    alert("div.RadEditor.Telerik:first : " + (end-start));
    start = new Date();
    for (i = 0; i < limit; i++) {
        var radeditor = $thisFrame.parents("div.RadEditor.Telerik")[0];
    }
    end = new Date();
    alert("(div.RadEditor.Telerik)[0] : " + (end-start));
    start = new Date();
    for (i = 0; i < limit; i++) {
        var $radeditor = $($thisFrame.parents("div.RadEditor.Telerik")[0]);
    }
    end = new Date();
    alert("$((div.RadEditor.Telerik)[0]) : " + (end-start));
}
/* end bench */

我认为第 3 次是最快的,第 4 次是最慢的,但这是我得出的结果:

FF3:    :eq(0)  :first  [0] $([0])
trial1  5275    4360    4107    3910
trial2  5175    5231    3916    4134
trial3  5317    5589    4670    4350
trial4  5754    4829    3988    4610
trial5  4771    6019    4669    4803
Average 5258.4  5205.6  4270    4361.4

IE6:    :eq(0)  :first  [0] $([0])
trial1  13796   15733   12202   14014
trial2  14186   13905   12749   11546
trial3  12249   14281   13421   12109
trial4  14984   15015   11718   13421
trial5  16015   13187   11578   10984
Average 14246   14424.2 12333.6 12414.8

我只是返回第一个本机 DOM 对象是最快的 ( [0]) 是正确的,但我不敢相信在 jQuery 函数中包装该对象比:first:eq(0)!

除非我做错了。

4

3 回答 3

15

根据 jQuery 的源代码,.first()它只是一个方便的包装器.eq(0)

first: function() {
    return this.eq( 0 );
},

从JQuery/3.6.0开始,这仍然是正确的。

于 2013-04-09T08:20:31.847 回答
7

2018 年:是的,:first:eq(0)返回相同的结果,尽管在 2018 年性能差异将是微不足道的,甚至可能微不足道。

2010:好问题和好帖子。我前段时间对此进行了测试,但不记得确切的结果。我真的很高兴找到了这个,因为这正是我想要的。

我猜想慢一点的原因很可能与解析性能有关:first:eq(0)省略这些允许 jQuery 引擎利用本机getElementsByTagNamegetElementsByClassName函数。

毫不奇怪,DOM 元素是访问速度最快的。在for循环中使用 jQuery 包装 DOM 元素不一定会对性能产生不利影响,因为 jQuery 使用expando属性进行缓存。

get(0)然而,看看如何与 DOM 元素访问进行比较,以及 jQuery 包装如何与其他结果进行比较,将会很有趣eq(0)

于 2010-01-21T10:02:21.910 回答
6

是的,它们是等价的。

不,它们不太可能有显着不同(其他都是微优化)。

于 2009-08-05T15:47:00.417 回答