JavaScript中伪数组如何使用和具体应用场景有哪些?

2026-03-31 15:471阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1399个文字,预计阅读时间需要6分钟。

JavaScript中伪数组如何使用和具体应用场景有哪些?

目录 + JavaScript中的伪数组 + 1. 什么是伪数组 + 2. 如何创建一个伪数组对象 + 3. 数组的concat方法 + JavaScript中的伪数组变真数组 + 伪数组和真数组的区别 + 总结 + JavaScript中的伪数组 + 1. 什么是伪数组 + JavaScript中的伪数组

目录
  • JavaScript中的伪数组
    • 1.什么是伪数组
    • 2.如何创建一个伪数组对象
    • 3.数组的concat方法
  • JavaScript伪数组变真数组
    • 伪数组与真数组的区别
  • 总结

    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)

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持自由互联。

    本文共计1399个文字,预计阅读时间需要6分钟。

    JavaScript中伪数组如何使用和具体应用场景有哪些?

    目录 + JavaScript中的伪数组 + 1. 什么是伪数组 + 2. 如何创建一个伪数组对象 + 3. 数组的concat方法 + JavaScript中的伪数组变真数组 + 伪数组和真数组的区别 + 总结 + JavaScript中的伪数组 + 1. 什么是伪数组 + JavaScript中的伪数组

    目录
    • JavaScript中的伪数组
      • 1.什么是伪数组
      • 2.如何创建一个伪数组对象
      • 3.数组的concat方法
    • JavaScript伪数组变真数组
      • 伪数组与真数组的区别
    • 总结

      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)

      总结

      以上为个人经验,希望能给大家一个参考,也希望大家多多支持自由互联。