文章目录
参考链接
https://wangdoc.com/javascript/stdlib/array.html#arrayisarray
es6数组新增方法
一、 静态方法
1.1 Array.isArray()
Array.isArray
方法返回一个布尔值,表示参数是否为数组
。它可以弥补typeof
运算符的不足。
var arr = [1, 2, 3];
typeof arr // "object"
Array.isArray(arr) // true
二、实例方法
2.1 改变原数组的方法
push(),pop()
push
方法用于在数组的末端添加一个或多个元素
,并返回添加新元素后的数组长度
。
const animals = ['pigs', 'goats', 'sheep'];
const count = animals.push('cows');
console.log(count);
// expected output: 4
pop
方法用于删除数组的最后一个元素
,并返回该元素
var plants = ['broccoli', 'cauliflower', 'cabbage', 'kale', 'tomato'];
console.log(plants.pop());
// expected output: "tomato"
shift(),unshift()
shift()
方法用于删除数组的第一个元素
,并返回该元素
。
var array1 = [1, 2, 3];
var firstElement = array1.shift();
console.log(array1);
// expected output: Array [2, 3]
console.log(firstElement);
// expected output: 1
unshift()
方法用于在数组的第一个位置添加元素
,并返回添加新元素后的数组长度
。
var array1 = [1, 2, 3];
console.log(array1.unshift(4, 5));
// expected output: 5
console.log(array1);
// expected output: Array [4, 5, 1, 2, 3]
reverse()
reverse
方法用于颠倒排列数组元素,返回改变后的数组
。
var a = ['a', 'b', 'c'];
a.reverse() // ["c", "b", "a"]
a // ["c", "b", "a"]
sort()
sort
方法对数组成员进行排序,默认是按照字典顺序排序。排序后,原数组将被改变。
['d', 'c', 'b', 'a'].sort()
// ['a', 'b', 'c', 'd']
[4, 3, 2, 1].sort()
// [1, 2, 3, 4]
[11, 101].sort()
// [101, 11]
[10111, 1101, 111].sort()
// [10111, 1101, 111]
上面代码的最后两个例子,需要特殊注意。sort()
方法不是按照大小排序
,而是按照字典顺序
。也就是说,数值会被先转成字符串
,再按照字典顺序进行比较,所以101
排在11
的前面。
如果想让sort方法按照自定义方式排序
,可以传入一个函数
作为参数。
[10111, 1101, 111].sort(function (a, b) {
return a - b;
})
// [111, 1101, 10111]
上面代码中,sort
的参数函数本身接受两个参数,表示进行比较的两个数组成员。如果该函数的返回值大于0
,表示第一个成员排在第二个成员后面;其他情况下,都是第一个元素排在第二个元素前面。
splice()
splice()
方法用于删除原数组的一部分成员,并可以在删除的位置添加新的数组成员
,返回值是被删除的元素
arr.splice(start, count, addElement1, addElement2, …);
splice
的第一个参数
是删除的起始位置(从0开始)
,第二个参数
是被删除的元素个数
。如果后面还有更多的参数
,则表示这些就是要被插入数组的新元素
。
var a = ['a', 'b', 'c', 'd', 'e', 'f'];
a.splice(4, 2) // ["e", "f"]
a // ["a", "b", "c", "d"]
上面代码从原数组4号位置,删除了两个数组成员。
var a = ['a', 'b', 'c', 'd', 'e', 'f'];
a.splice(4, 2, 1, 2) // ["e", "f"]
a // ["a", "b", "c", "d", 1, 2]
上面代码除了删除成员,还插入了两个新成员。
起始位置如果是负数
,就表示从倒数位置开始删除
。
var a = ['a', 'b', 'c', 'd', 'e', 'f'];
a.splice(-4, 2) // ["c", "d"]
上面代码表示,从倒数第四个位置c
开始删除两个成员。
如果只是单纯地插入元素
,splice
方法的第二个参数可以设为0
。
var a = [1, 1, 1];
a.splice(1, 0, 2) // []
a // [1, 2, 1, 1]
如果只提供第一个参数
,等同于将原数组在指定位置拆分成两个数组
。
var a = [1, 2, 3, 4];
a.splice(2) // [3, 4]
a // [1, 2]
2.2 不改变原数组的方法
join()
join()
方法以指定参数作为分隔符,将所有数组成员连接为一个字符串返回。如果不提供参数,默认用逗号分隔。
var a = [1, 2, 3, 4];
a.join(' ') // '1 2 3 4'
a.join(' | ') // "1 | 2 | 3 | 4"
a.join() // "1,2,3,4"
concat()
concat
方法用于多个数组的合并。它将新数组的成员,添加到原数组成员的后部,然后返回一个新数组,原数组不变
。
var arr1= ["1",'2','sdfs'];
var arr2 = ['ww','svsdv'];
console.log(arr1.concat(arr2));
//['1','2','sdfs','ww','svsdv']
console.log(arr1.concat(arr2,arr2,arr2));
//['1','2','sdfs','ww','svsdv','ww','svsdv','ww','svsdv']
console.log(arr1);//["1",'2','sdfs']
slice()
slice()方法用于提取目标数组的一部分
,返回一个新数组
,原数组不变。
arr.slice(start, end);
它的第一个参数为起始位置
(从0开始,会包括
在返回的新数组之中),第二个参数为终止位置
(但该位置的元素本身不包括
在内)。如果省略第二个参数,则一直返回到原数组的最后一个成员。
var a = ['a', 'b', 'c'];
a.slice(0) // ["a", "b", "c"]
a.slice(1) // ["b", "c"]
a.slice(1, 2) // ["b"]
a.slice(2, 6) // ["c"]
a.slice() // ["a", "b", "c"]
上面代码中,最后一个例子slice()没有参数,实际上等于返回一个原数组的拷贝。
如果slice()方法的参数是负数
,则表示倒数计算的位置
。
var a = ['a', 'b', 'c'];
a.slice(-2) // ["b", "c"]
a.slice(-2, -1) // ["b"]
上面代码中,-2
表示倒数
计算的第二个
位置,-1
表示倒数
计算的第一个
位置。
如果第一个参数大于等于数组长度
,或者第二个参数小于第一个参数
,则返回空数组
。
var a = ['a', 'b', 'c'];
a.slice(4) // []
a.slice(2, 1) // []
slice()
方法的一个重要应用,是将类似数组的对象转为真正的数组
。
Array.prototype.slice.call({ 0: 'a', 1: 'b', length: 2 })
// ['a', 'b']
Array.prototype.slice.call(document.querySelectorAll("div"));
Array.prototype.slice.call(arguments);
上面代码的参数都不是数组,但是通过call
方法,在它们上面调用slice()
方法,就可以把它们转为真正的数组。
map()
map
方法将数组的所有成员依次传入参数函数,然后把每一次的执行结果组成一个新数组返回
。
var numbers = [1, 2, 3];
numbers.map(function (n) {
return n + 1;
});
// [2, 3, 4]
numbers
// [1, 2, 3]
map
方法接受一个函数作为参数。该函数调用时,map
方法向它传入三个参数:当前成员
、当前位置
和数组本身
。
[1, 2, 3].map(function(elem, index, arr) {
return elem * index;
});
// [0, 2, 6]
上面代码中,map
方法的回调函数有三个参数,elem
为当前成员的值,index
为当前成员的位置,arr
为原数组([1, 2, 3]
)。
map
方法还可以接受第二个参数,用来绑定回调函数内部的this
变量
var arr = ['a', 'b', 'c'];
[1, 2].map(function (e) {
return this[e];
}, arr)
// ['b', 'c']