JavaScript获取数组最后一个元素的3种方法以及性能
前言
当需要从 JavaScript 中的数组中获取最后一个元素时,有多种选择,本文将提供 3 种可用方法。
1. 数组 length 属性
length
属性返回数组中元素的数量。从数组的长度中减去 1
得到数组最后一个元素的索引,使用它可以访问最后一个元素。从长度中减去 1
的原因是,在 JavaScript 中,数组索引编号从 0
开始。即第一个元素的索引将为 0
。因此,最后一个元素的索引将为数组的 length-1
。
const arrayTest = ["第一个元素", "第二个元素", "最后一个元素"]; const length = arrayTest.length; const lastValue = arrayTest[length - 1]; console.log(lastValue); // 最后一个元素
2. 数组 slice 方法
slice()
方法从一个数组中返回特定的元素,作为一个新的数组对象。此方法选择从给定开始索引开始到给定结束索引结束的元素,不包括结束索引处的元素。slice()
方法不会修改现有数组,提供一个索引值返回该位置的元素,负索引值从数组末尾计算索引。数组匹配的解构赋值用于从 slice()
方法返回的数组中获取元素。
const arrayTest = ["第一个元素", "第二个元素", "最后一个元素"]; const length = arrayTest.length; const [lastValue] = arrayTest.slice(-1); console.log(lastValue); // 最后一个元素
3. 数组 pop 方法
pop()
方法从数组中删除最后一个元素并将其返回,此方法会修改原来的数组。如果数组为空,则返回 undefined
并且不修改数组。
const arrayTest = ["第一个元素", "第二个元素", "最后一个元素"]; const length = arrayTest.length; const lastValue = arrayTest.pop(); console.log(lastValue); // 最后一个元素 console.log(arrayTest); // [ '第一个元素', '第二个元素' ]
性能比较
让按性能比较这 3 种方法。
const arrayTest = ["第一个元素", "第二个元素", "最后一个元素"]; console.time("==> length"); const length = arrayTest.length; let lastValue = arrayTest[length - 1]; console.log(lastValue); console.timeEnd("==> length"); console.time("====> slice"); let [lastValue1] = arrayTest.slice(-1); console.log(lastValue1); console.timeEnd("====> slice"); console.time("======> pop"); let lastValue2 = arrayTest.pop(); console.log(lastValue2); console.timeEnd("======> pop");
输出的结果如下:
最后一个元素
==> length: 6.38ms
最后一个元素
====> slice: 0.038ms
最后一个元素
======> pop: 0.033ms
总结
pop()
方法是最快的,如果可以修改数组,则可以使用它。如果你不想改变数组,可以使用 slice()
方法。利用数组 length 属性的方法是最慢的,属于是获取数组最后一个元素的最常用方法。
到此这篇关于JavaScript获取数组最后一个元素的3种方法以及性能的文章就介绍到这了,更多相关JS获取数组最后一个元素内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
js+css实现的圆角边框TAB选项卡滑动门代码分享(2款)
这篇文章主要为大家详细介绍了两种js+css实现的圆角边框TAB选项卡滑动门效果,很实用的代码,推荐给大家,有需要的小伙伴可以参考下2015-08-08仅IE6/7/8中innerHTML返回值忽略英文空格的问题
仅IE6/7/8中innerHTML返回值忽略英文空格的问题,需要此问题的朋友可以参考下。2011-04-04
最新评论