jQuery 等价于 Prototype array.last()

Posted

技术标签:

【中文标题】jQuery 等价于 Prototype array.last()【英文标题】:jQuery equivalent to Prototype array.last() 【发布时间】:2010-11-12 16:44:56 【问题描述】:

原型:

var array = [1,2,3,4];
var lastEl = array.last();

在 jQuery 中有什么类似的吗?

【问题讨论】:

试试这个***.com/questions/1159978/… 【参考方案1】:

为什么不只使用简单的 javascript

var array=[1,2,3,4];
var lastEl = array[array.length-1];

如果你愿意,你也可以把它写成一个方法(假设你的页面中没有包含原型):

Array.prototype.last = function() return this[this.length-1];

【讨论】:

因为像下面这样的东西看起来不太好: $('a').attr('href').split('#').last(); 我觉得不错。为什么说没有呢?对 .split() 的调用结束了链式能力,因此没有损失。 这是错误的。如果数组为空,则查找array[-1] @DisgruntledGoat ...这将返回undefined。这与 Prototype 的行为相同:prototypejs.org/api/array/last 你没有回答他的问题。是的,原始 javascript 可能更好,但问题是 jQuery 等价物。您提出的解决方案可能会在某些 jQuery 场景中产生不希望的情况(我自己有经验)【参考方案2】:

使用切片():

var a = [1,2,3,4];
var lastEl = a.slice(-1)[0]; // 4
// a is still [1,2,3,4]

用 pop();

var a = [1,2,3,4];
var lastEl = a.pop(); // 4
// a is now [1,2,3]

更多信息请参见https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array

【讨论】:

为什么不只是 .slice().pop() 复制数组并从副本中弹出一个元素? @gnarf 我猜是因为使用.slice() 复制所有数组可能比使用.slice(-1) 仅复制最后一个元素更昂贵【参考方案3】:

当处理一个 jQuery 对象时,.last() 会这样做,将匹配的元素过滤到集合中的最后一个。

当然,您可以使用 jQuery 包装一个原生数组,从而实现:

var a = [1,2,3,4];
var lastEl = $(a).last()[0];

【讨论】:

【参考方案4】:

为什么不用get函数?

var a = [1,2,3,4];
var last = $(a).get(-1);

http://api.jquery.com/get/更多信息

编辑: 正如 DelightedD0D 所指出的,这不是根据 jQuery 文档使用的正确函数,但它仍然提供正确的结果。我建议使用 Salty 的答案来保持您的代码正确。

【讨论】:

鉴于提出的问题,我认为这是最相关和最优雅的答案。根据 jQuery 文档:“负索引从匹配集的末尾开始计算,因此此示例返回列表中的最后一项:”谢谢。 这是错误的,.get() - Retrieve the DOM elements matched by the jQuery object.。这并不意味着在这样的数组上使用。 @DelightedD0D 在这种情况下,您已经回答了我回答中的“为什么不”部分。【参考方案5】:

对于数组,您可以简单地使用 array.length - 1 检索最后一个元素位置:

var a = [1,2,3,4];

var lastEl = a[a.length-1]; // 4

在 jQuery 中,您有 :last 选择器,但这对普通数组没有帮助。

【讨论】:

【参考方案6】:

如果你在数组上使用原型:

Array.prototype.last = function() return this[this.length-1];

使用 forloops 可以做到这一点。

var a = [0,1,2];
out --> 0
out --> 1
out --> 2
out --> last

【讨论】:

你应该使用 hasOwnProperty 来避免这种情况。【参考方案7】:

我知道答案已经给出,但我想我有另一个解决方案。 您可以将数组反转并输出第一个数组项,如下所示:

var a = [1,2,3,4];
var lastItem = a.reverse()[0];

对我来说很好。

【讨论】:

反转数组只是为了得到最后一个值是不必要的昂贵。此外,原始数组也会被修改。 方法仍然返回最后一个元素。所以我看不出反对票的理由。在这里 +1。 男孩,您的处理器需要更多工作才能获得相同的结果。这是一种没有收益的资源浪费。你看不出来吗? “只为我工作”是一个荒谬的口头禅。【参考方案8】:

根据jsPerf: Last item method,性能最高的方法是array[array.length-1]。该图显示每秒操作数,而不是每次操作的时间。

开发人员认为单个操作的性能很重要是很常见的(但错误的)。它不是。仅当您执行大量相同操作时,性能才重要。在这种情况下,使用静态值 (length) 访问特定索引 (length-1) 是最快的,而且还差得远。

【讨论】:

【参考方案9】:

查看这些测试用例http://jsperf.com/last-item-method 最有效的方法是通过 .pop 方法(在 V8 中),但会丢失数组的最后一个元素

【讨论】:

很多人谈论这种方式或那种方式的性能更高,有人发布了一个展示性能的链接,但没有点赞。当然,这可能是因为他倒读了图表。我已经更正并扩展了他的 cmets。 @MichaelBlackburn 嘿!我在审核队列中发现了您的编辑,并认为我应该解释为什么它被拒绝,尽管它更准确。简单地说:edits shouldn't change the content of a post, even to fix factual errors——相反,最好对这些答案投反对票并留下评论解释原因。当然,您是绝对正确的,所以也许您可以使用 accurate 性能信息添加您自己的答案?我会赞成! :)【参考方案10】:

网址:www.mydomain.com/user1/1234

$.params = window.location.href.split("/"); $.params[$.params.length-1];

您可以根据查询字符串分隔符进行拆分

【讨论】:

【参考方案11】:

你可以使用这个Arr.slice(-1)[0]

Arr=[1,2,3,4,5,6,7]

让我们明白这一点。 -1 表示您正在查找 Array 的最后一个索引。 因此,当您使用 Arr.slice(-1)[0] 时,您将得到结果:7

【讨论】:

【参考方案12】:

SugarJS

它不是 jQuery,而是另一个你可能会发现除了 jQuery 之外有用的库:试试SugarJS。

Sugar 是一个 Javascript 库,它使用有用的方法扩展原生对象。它旨在直观、不显眼,让您用更少的代码做更多的事情。

使用 SugarJS,您可以:

[1,2,3,4].last()    //  => 4

这意味着,您的示例确实可以开箱即用:

var array = [1,2,3,4];
var lastEl = array.last();    //  => 4

更多信息

SugarJS Homepage Feature Overview All about arrays in SugarJS

【讨论】:

【参考方案13】:

我用这个:

array.reverse()[0]

你用 reverse() 反转数组,然后用 [0] 选择反转版本的第一项,即原始数组的最后一项。

如果您当然不关心数组是否被反转,您可以使用此代码,因为它会一直如此。

【讨论】:

反转数组,取反转版本的第一个,所以原来的最后一个 这是 O(n),因为它会反转整个数组,即使您只需要最后一个条目。 Salty 的答案是 O(1),随着数组变长,它的速度会更快。

以上是关于jQuery 等价于 Prototype array.last()的主要内容,如果未能解决你的问题,请参考以下文章

jQuery入门

从 Prototype 迁移到 jQuery (Rails) 的策略

js中的constructor与prototype

非 jQuery 等价于:在 ​​JavaScript 中可见?

jQuery 等价于 body onLoad

等价于纯 JS 中 jQuery 的 contents().find() 链式方法