1 概述
1.1 前言
JavaScript数组方法速查手册极简版*收了32个数组的常用方法和属性,并根据方法的用途进行重新排序和分类,在文中简要的介绍了方法作用和用例说明。收藏备用吧!
文中介绍的过于简单,想更更多理解相关内容还是要多多动手实践!
2 数组属性
2.1 length-长度属性
每个数组都有一个length属性。针对稠密数组,length属性值代表数组中元素的个数。当数组是稀疏数组时,length属性值大于元素的个数。
var array1 = [ 'a', 'b', 'c' ];
console.log(array1.length); // 输出 3
array1.length = 2;
console.log(array1); // 输出 [ "a", "b" ]
3 数组方法
3.1 Array.isArray-类型判定
Array.isArray()
数组类型判定。
console.log(Array.isArray([1, 2, 3])); // 输出 true
console.log(Array.isArray({num: 123})); //输出 false
3.2 Array.of-创建数组
Array.of()
从可变数量的参数创建数组,不管参数的数量或类型如何。
console.log(Array.of(3)); // 输出 [3]
console.log(Array.of(1,2,3)); // 输出 [1,2,3]
3.3 Array.from-创建数组
Array.from()
用类数组或可迭代对象创建新数组。
console.log(Array.from('abcd')); // 输出 [ "a", "b", "c", "d" ]
console.log(Array.from([1, 2, 3], x => x + 1)); // 输出 [ 2, 3, 4 ]
4 数组原型方法
4.1 查找元素
4.1.1 find-按函数查找
Array.prototype.find()
找到第一个满足检测函数条件的元素,并返回该元素,没找到则返回 undefined。
var array1 = [1, 2, 3, 4, 5];
console.log(array1.find(x => x > 3)); // 输出 4
4.1.2 findIndex-按函数查找
Array.prototype.findIndex()
找到第一个满足检测函数条件的元素,并返回该元素索引。找不到返回-1。
var array1 = [6, 7, 8, 9, 10];
console.log(array1.findIndex(x => x > 8)); // 输出 3
4.1.3 indexOf-按元素值查找
Array.prototype.indexOf()
查找元素并返回元素索引值,找不到返回-1。
var arr= [1, 2, 3, 4];
console.log(arr.indexOf(3)); // 输出 2
console.log(arr.indexOf(6)); // 输出 -1
console.log(arr.indexOf(2, 2)); // 输出 -1
第二个参数表示查找的起始位置。
4.1.4 lastIndexOf-按元素值查找
Array.prototype.lastIndexOf()
从后向前查找元素并返回元素索引值,找不到返回 -1。
var arr = ['a', 'b', 'c', 'd'];
console.log(arr.lastIndexOf('b')); // 输出 1
console.log(arr.lastIndexOf('e')); // 输出 -1
4.2 添加元素
4.2.1 push-尾部添加
Array.prototype.push()
在尾部添加一个或多个元素,返回数组的新长度。
var array1= ['a', 'b', 'c'];
console.log(array1.push('d')); // 输出 4
console.log(array1); // 输出 [ "a", "b", "c", "d" ]
4.2.2 unshift-头部添加
Array.prototype.unshift()
在头部添加一个或多个元素,并返回数组的新长度。
var array1 = [ 4, 5, 6 ];
console.log(array1.unshift(3)); // 输出 4
console.log(array1); // 输出 [ 3, 4, 5, 6 ]
console.log(array1.unshift(1, 2)); // 输出 6
console.log(array1); // 输出 [ 1, 2, 3, 4, 5, 6 ]
4.3 删除元素
4.3.1 pop-尾部删除
Array.prototype.pop()
从尾部删除一个元素,并返回该元素。
var array1= ['a', 'b', 'c', 'd'];
console.log(array1.pop()); // 输出 d
console.log(array1); // 输出 [ "a", "b", "c" ]
4.3.2 shift-头部删除
Array.prototype.shift()
从头部删除一个元素,并返回该元素。
var array1 = [1, 2, 3];
console.log(array1.shift()); // 输出 1
console.log(array1); // 输出 [ 2, 3 ]
4.4 替换元素
4.4.1 splice-添加替换删除
Array.prototype.splice()
添加、替换、删除元素。会改变原数组。
var array1 = [ 'a', 'c', 'd' ];
array1.splice( 1, 0, 'b');
console.log(array1); // 输出 [ "a", "b", "c", "d" ]
array1.splice(1,1);
console.log(array1); // 输出 [ "a", "c", "d" ]
array1.splice(1,1,'bb','cc');
console.log(array1); // 输出 [ "a", "bb", "cc", "d" ]
array.splice(start[, deleteCount[, item1[, item2[, ...]]]])
- 参数
start
:表示替换的位置 - 参数
deleteCount
:表示删除元素的数量 - 参数
item1...
: 表示添加的元素
4.5 顺序相关
4.5.1 sort-排序
Array.prototype.sort()
数组排序,改变原数组。
var array1 = [ 4, 3, 10, 2 ];
console.log(array1.sort()); // 输出 [ 10, 2, 3, 4 ]
console.log(array1.sort((x1, x2) => x1 > x2)); // 输出 [ 2, 3, 4, 10 ]
4.5.2 reverse-反序
Array.prototype.reverse()
倒置数组,并返回新数组。会改变原数组。
var sourceArray= [ 'a', 'b', 'c' ];
var reverseArray = sourceArray.reverse();
console.log(reverseArray); // 输出 [ "c", "b", "a" ]
console.log(sourceArray == reverseArray); // 输出 true
4.6 遍历迭代
4.6.1 keys-键迭代器
Array.prototype.keys()
数组的键迭代器。
var array1 = ['a', 'b', 'c'];
for (let key of array1.keys()) {
console.log(key); // 输出 0, 1, 2
}
4.6.2 values-值迭代器
Array.prototype.values()
数组的值迭代器。
const array1 = ['a', 'b', 'c'];
const iterator = array1.values();
for (const value of iterator) {
console.log(value); // 输出 a b c
}
4.6.3 entries-键/值对迭代器
Array.prototype.entries()
数组的键/值对迭代器。
var array1 = ['a', 'b', 'c'];
var iterator1 = array1.entries();
console.log(iterator1.next().value); // 输出 Array [0, "a"]
console.log(iterator1.next().value); // 输出 Array [ 1, "b" ]
4.6.4 forEach-遍历
Array.prototype.forEach()
遍历数组中的元素,并执行回调函数。
var arr = [1, 2, 3, 4];
arr.forEach(function (x) {
console.log(x + 1); // 输出 2 3 4 5
});
4.7 检测
4.7.1 includes-值包含检测
Array.prototype.includes()
值包含检测,如包含返回 true,不包含返回false。
var array1 = [1, 2, 3];
console.log(array1.includes(2)); // 输出 true
console.log(array1.includes(4)); // 输出 false
4.7.2 some-函数包含检测
Array.prototype.some()
检测数组中是否有元素可以通过检测函数验证。
var array1 = [ 1, 2, 3, 4 ];
console.log(array1.some(x => x >3)); // 输出 true
console.log(array1.some(x => x > 5)); // 输出 false
4.7.3 every-函数完全检测
Array.prototype.every()
检测数组中是否所有元素都可以通过检测函数验证。
var array1 = [ 1, 2, 3, 4, 5 ];
console.log(array1.every(x => x < 8)); //输出 true
console.log(array1.every(x => x < 4)); //输出 false
4.8 合并
4.8.1 join-合并成字符串
Array.prototype.join()
合并数组中所有元素成为字符串并返回。
var array1= [ 'a', 'b', 'c' ];
console.log(array1.join()); // 输出 a,b,c
console.log(array1.join("-")); // 输出 a-b-c
4.8.2 concat-合并成数组
Array.prototype.concat()
合并两个或多个数组,返回一个全新数组,原数组不变。
var array1 = [ 'a', 'b' ];
var array2 = [ 'c', 'd' ];
console.log(array1.concat(array2)); // 输出 [ "a", "b", "c", "d" ]
该方法可以有多个参数。
4.9 累计
4.9.1 reduce-左侧累计
Array.prototype.reduce()
从左至右按 reducer
函数组合元素值,并返回累计器终值。
const array1 = [1, 2, 3, 4];
const reducer = (accumulator, currentValue) => accumulator + currentValue;
// 1 + 2 + 3 + 4
console.log(array1.reduce(reducer)); // 输出 10
// 5 + 1 + 2 + 3 + 4
console.log(array1.reduce(reducer, 5)); // 输出 15,其中5是累计器初始值。
4.9.2 reduceRight-右侧累计
Array.prototype.reduceRight()
从右至左按 reducer
函数组合元素值,并返回累计器终值。
const array1 = [1, 2, 3, 4];
const reducer = (accumulator, currentValue) => accumulator.concat(currentValue);
console.log(array1.reduceRight(reducer)); // 输出 [ 4, 3, 2, 1 ]
console.log(array1.reduceRight(reducer, 5)); // 输出 [ 5, 4, 3, 2, 1 ]
4.10 copyWithin-内部复制
Array.prototype.copyWithin()
数组内部复制,不改变原数组长度。
var array1 = ['a', 'b', 'c', 'd', 'e','f'];
console.log(array1.copyWithin(0, 3, 5)); // 输出 [ "d", "e", "c", "d", "e", "f" ]
console.log(array1.copyWithin(1, 3)); // 输出 [ "d", "d", "e", "f", "e", "f" ]
arr.copyWithin(target[, start[, end]])
- 参数
target
: 表示要复制到的索引位置,如为负值则从后向前计数。 - 参数
start
: 表示要复制序列的起始索引位置,如为负值则从后向前计数。如省略该值,则从索引0开始。 - 参数
end
: 表示要复制序列的结束位置,如为负值则从后向前计数。如省略该值,则复制到结尾位置。
4.11 fill-填充函数
Array.prototype.fill()
用固定值填充起始索引到终止索引区间内的全部元素值,不包括终止索引。
var array1 = [1, 2, 3, 4];
console.log(array1.fill(9, 2, 4)); // 输出 [ 1, 2, 9, 9 ]
console.log(array1.fill(8, 1)); // 输出 [ 1, 8, 8, 8 ]
console.log(array1.fill(7)); // 输出 [ 7, 7, 7, 7 ]
4.12 filter-过滤函数
Array.prototype.filter()
生成由通过检测函数验证元素组成的新数组并返回。
var arr = [ 9 , 8 , 7 , 6];
console.log(arr.filter(x => x >7)); //输出 [ 9, 8 ]
4.13 flat-数组扁平化
Array.prototype.flat()
按指定深度递归遍历数组,并返回包含所有遍历到的元素组成的新数组。不改变原数组。
var arr1 = [ 1, 2, [ 3, 4 ] ];
console.log(arr1.flat()); // 输出 [ 1, 2, 3, 4 ]
var arr2 = [ 1, 2, [3, 4, [ 5, 6 ] ] ];
console.log(arr2.flat()); // 输出 [ 1, 2, 3, 4, [ 5, 6 ] ]
var arr3 = [1, 2, [ 3, 4, [ 5, 6 ] ] ];
console.log(arr3.flat(2)); // 输出 [ 1, 2, 3, 4, 5, 6 ]
4.14 map-映射
Array.prototype.map()
创建一个新数组,该数组中的元素由原数组元素调用map函数产生。
var array1 = [1, 2, 3, 4];
console.log(array1.map(x => x * 2)); // 输出 [ 2, 4, 6, 8 ]
4.15 slice-截取数组
Array.prototype.slice()
按参数begin
和 end
截取数组,不改变原数组。
var array1 = [ 1, 2, 3, 4, 5];
console.log(array1.slice( 2, 4 )); //输出 [ 3, 4 ]
console.log(array1); //输出 [ 1, 2, 3, 4, 5 ]
5 结尾
5.1 结语
文中介绍的过于简单,想更多理解相关内容还是要多多动手实践!
因时间不足,能力有限等原因,存在文字阐述不准及代码测试不足等诸多问题。如发现错误请不吝指正!谢谢。
最后,给大家推荐一个前端学习进阶内推交流群685910553(前端资料分享),不管你在地球哪个方位,
不管你参加工作几年都欢迎你的入驻!(群内会定期免费提供一些群主收藏的免费学习书籍资料以及整理好的面试题和答案文档!)
如果您对这个文章有任何异议,那么请在文章评论处写上你的评论。
如果您觉得这个文章有意思,那么请分享并转发,或者也可以关注一下表示您对我们文章的认可与鼓励。
愿大家都能在编程这条路,越走越远。