JavaScript中的伪数组用法及说明

 更新时间:2023年02月10日 16:35:57   作者:高先生的猫  
这篇文章主要介绍了JavaScript中的伪数组用法及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

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伪数组变真数组

首先介绍两种非常简单直接的方法(伪数组为可迭代对象):

[...伪数组] // ES6的语法糖,直接将伪数组(对象)变为真数组
Array.from(伪数组) // Array中的静态方法,直接将伪数组(对象)变为真数组

下面讲解伪数组和真数组的区别,还有利用数组的方法将伪数组变为真数组:

伪数组与真数组的区别

  • 伪数组是对象
  • 伪数组原型是Object,而不是Array
  • 所以伪数组没有数组的方法,如push()、shift()、find()等等
  • 伪数组的属性名与数组的下标相似,以0,1,2,… 等的数字表示,也拥有length属性

数组的方法对象能用的上吗?==> 因为数组的大部分方法是要遍历数组,进行处理再创建一个新数组放回的,而数组项的调用 arr[i] 这种形式对象也能用,所以伪数组这个对象能适应部分数组方法

伪数组是对象,那怎么利用数组的方法呢?==> 可以使用 [].数组方法.call(伪数组, 参数...) 或 [].数组方法.apply(伪数组, 参数) 来调用

所以利用伪数组与数组的相似点(属性与下标相似,拥有length属性,都可以用 [ ] 调用),可以很容易的利用数组的方法将伪数组变为真数组。

// 下面我尝试使用了数组中所以可能的方法,得出下列能将伪数组变为数组的方法
// 函数中的 arguments 是存储函数参数列表和特殊方法的对象,它是一个伪数组,我们将以它为例进行尝试
// 在实际应用中,如果伪数组为可迭代对象,直接运用前两种最简单的方法就够了

function fun1(v1, v2, v3) {
    console.log('-----------------arguments-------------------')
    console.log(arguments) // Arguments { 0: 1, 1: 2, 2: 3, … }
    console.log(Array.isArray(arguments)) // false
    console.log('------------------------------------')
    
    let x = null  // 定义变量x,接收伪数组转化后的结果
    
    // 简单方法(伪数组为可迭代对象)
    x = [...arguments]
    
    x = Array.from(arguments)
    
    
    // 调用数组方法
    x = [].filter.call(arguments, v => true)
    
    x = [].map.call(arguments, v => v)
    
    x = [].slice.call(arguments)


    // 上面各个方法调用后,成功将伪数组转为真数组,其返回的真数组都是一样的,如下
    console.log(x) // Array(3) [ 1, 2, 3 ]
    console.log(Array.isArray(x)) // true
} 

fun1(1, 2, 3)

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • js模拟实现京东详情页图片放大效果

    js模拟实现京东详情页图片放大效果

    这篇文章主要为大家详细介绍了js模拟实现京东详情页图片放大效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • DWR中各种java方法的调用

    DWR中各种java方法的调用

    DWR是一个框架,简单的说就是能够在javascript直接调用java方法,而不必去写一大堆的javascript代码。它的实现是基于ajax的,可以实现无刷新效果。不少DWR的例子,但大都只是某种方法的调用只在使用层面上介绍DWR,并不涉更多的技术与设计javascript中是如何调用的。
    2016-05-05
  • JavaScript截取字符串的2个函数介绍

    JavaScript截取字符串的2个函数介绍

    这篇文章主要介绍了JavaScript截取字符串的2个函数介绍,它们分别是substring和substr函数,本文用实例讲解了它们的用法,需要的朋友可以参考下
    2014-08-08
  • JavaScript实现三级级联特效

    JavaScript实现三级级联特效

    这篇文章主要介绍了JavaScript实现三级级联特效,选择省会出现相应的县下拉框,同时市的下拉框改变,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • ES7之Async/await的使用详解

    ES7之Async/await的使用详解

    这篇文章主要介绍了ES7之Async/await的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • js判断用户是输入的地址请求的路径(实例讲解)

    js判断用户是输入的地址请求的路径(实例讲解)

    下面小编就为大家带来一篇js判断用户是输入的地址请求的路径(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • js页面跳转的常用方法整理

    js页面跳转的常用方法整理

    跳转页面的方法有很多,在本文整理了一些比较常用,并有示例代码,感兴趣的朋友可以参考下
    2013-10-10
  • js简单实现HTML标签Select联动带跳转

    js简单实现HTML标签Select联动带跳转

    Select联动带跳转的效果想必大家并不陌生吧,下面有个不错的示例,感兴趣的朋友可以参考下
    2013-10-10
  • javascript实现京东快递单号的查询效果

    javascript实现京东快递单号的查询效果

    这篇文章主要为大家详细介绍了javascript实现京东快递单号的查询效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • 使用js检测浏览器是否支持html5中的video标签的方法

    使用js检测浏览器是否支持html5中的video标签的方法

    这篇文章主要介绍了使用js检测浏览器是否支持html5中的video标签的方法,需要的朋友可以参考下
    2014-03-03

最新评论