了解JavaScript中的伪数组
Posted forceddd
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了了解JavaScript中的伪数组相关的知识,希望对你有一定的参考价值。
1.什么是伪数组
javascript中存在有一种类数组,或者说伪数组。经常见到的伪数组有函数的arguments
对象、dom.querySelectorAll
等获取的NodeList
类(NodeList
本身具有forEach
方法)等。
伪数组并不是数组,它没有继承Array.prototype
,但是它“看起来像数组”,它本身没有数组的标准方法,但是它可以复用这些标准方法。
例子
function arrayLike() {
arguments.forEach(a => console.log(a));//TypeError: arguments.forEach is not a function
}
arrayLike(1, 2, 3);
如上例所示,arguments
对象本身并没有forEach
方法,但是它可以复用数组的这些标准方法。
例子
function arrayLike() {
// arguments.forEach(a => console.log(a));
[].forEach.call(arguments, a => console.log(a));// 1 2 3 通过call改变this指向,调用数组的方法
[...arguments].forEach(a => console.log(a));// 1 2 3 构建一个真实数组,然后调用数组的方法
}
arrayLike(1, 2, 3);
2.如何创建一个伪数组对象
一个数组对象必然具有两个特点:
- 具有一个范围在 0~232-1 的整型length属性
- length属性大于该对象的最大索引,索引是一个 0-232 -2 范围内的整数
所以很简单,只要实现这两个特点,一个对象就是伪数组对象了。
例子
const arr = {
1: \'AAA\',
3: \'CCC\',
length: 8,
};
[].forEach.call(arr, (item, i) => console.log(item, i)); //AAA 1 CCC 3
3.数组的concat
方法
对于数组和伪数组,在数组的标准方法中,只有concat
方法是不通用的,对于一个伪数组,concat
方法会将其作为一个整体连接起来。
例子
console.log([].concat.call(arr, [7, 8]));//[ { \'1\': \'AAA\', \'3\': \'CCC\', length: 8 }, 7, 8 ]
console.log([1, 2].concat([7, 8]));//[ 1, 2, 7, 8 ]
上例展示了数组和伪数组调用concat
的不同结果,在遇到这种情况时,我们只有自己对伪数组进行转换,比如:
1.通过slice方法,复制伪数组
console.log([].concat.call([].slice.call(arr), [7, 8]));
//[ <1 empty item>, \'AAA\', <1 empty item>, \'CCC\', <4 empty items>, 7, 8 ]
2.通过Symbol.isConcatSpreadable
改变对伪数组对象进行concat
操作时的默认行为
const arr = {
1: \'AAA\',
3: \'CCC\',
length: 8,
[Symbol.isConcatSpreadable]: true,
};
console.log([].concat.call(arr, [7, 8]));
//[ <1 empty item>, \'AAA\', <1 empty item>, \'CCC\', <4 empty items>, 7, 8 ]
以上是关于了解JavaScript中的伪数组的主要内容,如果未能解决你的问题,请参考以下文章