Array 类型
转换方法
记录点 1 所有对象都具有 toLocaleString()、toString()和 valueOf()方法。
array.join
栈方法
array.push, array.pop
队列方法
array.shift, array.push
重排方法
array.reverse, array.sort
- sort()方法可以接收一个比较函数作为参 数,以便我们指定哪个值位于哪个值的前面。
- reverse()和 sort()方法的返回值是经过排序之后的数组。
操作方法
array.concat, array.slice
- concat()方法可以基于当前数 组中的所有项创建一个新数组。
- slice()方法不会影响原始数组。如果 slice()方法的参数中有一个负数,则用数组长度加上该数来确定相应的位 置。例如,在一个包含 5 项的数组上调用 slice(-2,-1)与调用 slice(3,4)得到的 结果相同。如果结束位置小于起始位置,则返回空数组。
array.splice
- 删除: 可以删除任意数量的项,只需指定 2 个参数:要删除的第一项的位置和要删除的项数。 例如,splice(0,2)会删除数组中的前两项。
- 插入: 可以向指定位置插入任意数量的项,只需提供 3 个参数:起始位置、0(要删除的项数) 和要插入的项。如果要插入多个项,可以再传入第四、第五,以至任意多个项。例如, splice(2,0,“red”,“green”)会从当前数组的位置 2 开始插入字符串"red"和"green"。
- 替换: 可以向指定位置插入任意数量的项,且同时删除任意数量的项,只需指定 3 个参数:起 始位置、要删除的项数和要插入的任意数量的项。插入的项数不必与删除的项数相等。例如, splice (2,1,“red”,“green”)会删除当前数组位置 2 的项,然后再从位置 2 开始插入字符串 “red"和"green”。
splice()方法始终都会返回一个数组,该数组中包含从原始数组中删除的项(如果没有删除任何 项,则返回一个空数组)。
位置方法
array.indexOf, array.lastIndexOf
迭代方法
array.every, array.filter, array.forEach, array.map, array.some
- every(): 对数组中的每一项运行给定函数,如果该函数对每一项都返回 true,则返回 true。
- filter(): 对数组中的每一项运行给定函数,返回该函数会返回 true 的项组成的数组。
- forEach(): 对数组中的每一项运行给定函数。这个方法没有返回值。
- map(): 对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。
- some(): 对数组中的每一项运行给定函数,如果该函数对任一项返回 true,则返回 true。
以上方法都不会修改数组中的包含的值。
归并方法
array.reduce, array.reduceRight (ECMAScript 5 新增)
- 其中,reduce()方法从数组的第一项开始,逐个遍历 到最后。而 reduceRight()则从数组的最后一项开始,向前遍历到第一项。
- 这两个方法都接收两个参数:一个在每一项上调用的函数和(可选的)作为归并基础的初始值。传给 reduce()和 reduceRight()的函数接收 4 个参数:前一个值、当前值、项的索引和数组对象。第一次迭代发生在数组的第二项上,因此第 一个参数是数组的第一项,第二个参数就是数组的第二项。
ES6 方法
2019-02-06 增加
array.fill, Array.from
function makeRow(v = 0) {
const array = new Array(9);
array.fill(v);
return array;
}
function makeMatrix(v = 0) {
return Array.from({length: 9}, () => makeRow(v));
}
const a = makeMatrix();
a[0][1] = 2;
console.log(a);
// 输出结果:9 * 9 宫格,其中 [0][1] 号元素数值是 2,其他均为 0
至此,结束。
本文详细介绍了JavaScript中Array类型的多种方法,包括转换、栈、队列、重排、操作、位置、迭代及归并方法。此外,还介绍了ES6新增的fill和from方法,以及如何使用这些方法进行数组的填充和创建。
2870

被折叠的 条评论
为什么被折叠?



