前端JavaScript篇之JavaScript 类数组对象的定义?如何将类数组对象转换为真正的数组

目录

  • JavaScript 类数组对象的定义?如何将类数组对象转换为真正的数组
  • 如何将类数组对象转换为真正的数组


JavaScript 类数组对象的定义?如何将类数组对象转换为真正的数组

类数组对象指的是具有类似数组结构(类似于数组的属性或方法)的普通JavaScript对象。尽管它们不是真正的数组,但可以像数组一样进行一些类似的操作。通常,类数组对象具有数值索引和length属性,但不具有数组的原型方法如pushpop等。

一个常见的类数组对象的例子是 arguments 对象,它保存了函数调用时传递的所有参数,并且可以通过索引访问每个参数。

以下是一个案例介绍和示例代码:

假设有一个函数sum,它可以接收任意个数的参数,并返回所有参数的和。

function sum() {var argArray = Array.prototype.slice.call(arguments) // 将 arguments 对象转换为真正的数组var total = 0for (var i = 0; i < argArray.length; i++) {total += argArray[i]}return total
}// 示例:求 1 到 5 的和
var result = sum(1, 2, 3, 4, 5)
console.log(result) // 输出 15

在上述代码中,arguments 对象是一个类数组对象,它类似于数组,但是不具有数组的方法。为了将它转换为真正的数组,我们使用 Array.prototype.slice.call(arguments) 将其转换为一个数组 argArray。接着,我们使用 for 循环遍历 argArray 中的每个元素,并将它们累加起来,最后返回累加的结果。

通过将类数组对象转换为真正的数组,我们可以使用数组的方法和属性在类数组对象上进行更方便的操作。

如何将类数组对象转换为真正的数组

下面我将介绍其中三种常用的方法:

  1. Array.from() 方法:
    这是一个数组静态方法,它从类数组对象或可迭代对象创建一个新的数组实例。它将类数组对象的每个元素作为新数组的元素,并返回这个新数组。
var arrayLike = { 0: 'apple', 1: 'banana', 2: 'orange', length: 3 }
var newArray = Array.from(arrayLike)
console.log(newArray)

运行结果:

['apple', 'banana', 'orange']

请添加图片描述

Array.from() 方法接受一个类数组对象作为参数,并使用对象的 length 属性和索引来创建一个新的数组。返回的数组将包含类数组对象的每个元素。

  1. Array.prototype.slice.call() 方法:
    这种方法使用数组的原型方法 slice(),并将其应用于类数组对象。通过在 slice 方法上调用 call() 方法,并将类数组对象作为参数传递,可以将类数组对象转换为一个新的数组。
var arrayLike = { 0: 'apple', 1: 'banana', 2: 'orange', length: 3 }
var newArray = Array.prototype.slice.call(arrayLike)
console.log(newArray)

运行结果:

['apple', 'banana', 'orange']

请添加图片描述

这段代码中,Array.prototype.slice.call(arrayLike)slice() 方法应用于 arrayLike 对象,将其转换为一个数组。slice() 方法接受类数组对象作为其上下文,并返回一个新的数组,其中包含类数组对象的元素。

  1. Array.prototype.concat.apply() 方法:
    这种方法使用数组的原型方法 concat()apply(),将类数组对象作为参数应用于 concat() 方法。
var arrayLike = { 0: 'apple', 1: 'banana', 2: 'orange', length: 3 }
var newArray = Array.prototype.concat.apply([], arrayLike)
console.log(newArray)

运行结果:

['apple', 'banana', 'orange']

请添加图片描述

这段代码中,Array.prototype.concat.apply([], arrayLike) 将空数组作为上下文应用于 concat() 方法,然后将类数组对象 arrayLike 作为参数传递。apply() 方法将数组作为参数展开,并返回一个新的数组。

这些方法都可以将一个类数组对象转换为一个真正的数组。你可以根据具体的使用场景和个人偏好选择其中的一种。

持续学习总结记录中,回顾一下上面的内容:
类数组对象是指具有数组特性(例如 length 属性和下标访问元素)但不是真正的数组对象,常见的有函数的 arguments 参数、DOM 元素集合和 NodeList 等。将类数组对象转换为真正的数组可以使用以下几种方式:

  1. 使用 Array.from() 方法,将类数组对象转换为数组。
  2. 使用扩展运算符 ...,将类数组对象转换为数组。
  3. 使用 Array.prototype.slice.call() 方法,将类数组对象转换为数组。
  4. 使用 Array.prototype.concat.apply([], arrLike) 方法,将类数组对象转换为数组。

这些方法都可以将类数组对象转换为真正的数组,方便进行数组相关的操作和方法调用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/452478.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VS2019+CAXACAD2023二次开发教程(一、环境搭建)

前言 CAXACAD2023的二次开发相关文件和库都在installpath\CRX\的文件夹下。 CAXACAD2023的默认开发环境是VS2019,如果是用VS2019的环境话,可以直接安装"installpath\CRX\Wizard\CRXWizard_VS2019.exe"这个插件,安装好后就可以一键新建的项目,新建的项目会自动帮…

李沐《动手学深度学习》循环神经网络 经典网络模型

系列文章 李沐《动手学深度学习》预备知识 张量操作及数据处理 李沐《动手学深度学习》预备知识 线性代数及微积分 李沐《动手学深度学习》线性神经网络 线性回归 李沐《动手学深度学习》线性神经网络 softmax回归 李沐《动手学深度学习》多层感知机 模型概念和代码实现 李沐《…

1-2 动手学深度学习v2-基础优化方法-笔记

最常见的算法——梯度下降 当一个模型没有显示解的时候&#xff0c;该怎么办呢&#xff1f; 首先挑选一个参数的随机初始值&#xff0c;可以随便在什么地方都没关系&#xff0c;然后记为 w 0 \pmb{w_{0}} w0​在接下来的时刻里面&#xff0c;我们不断的去更新 w 0 \pmb{w_{0}…

Java项目服务器部署

Java项目服务器部署 Tomocat Java项目进行云服务器部署 如果有需要比赛部署的同学也可以联系我&#xff0c;我后续还会对于这个专栏继续展开 1、云服务器选购 1.1 阿里云选购&#xff08;宝塔面板&#xff09; 1.2 端口放行 这里说的就是端口放行&#xff0c;后面一些访问比…

Electron实战(一):环境搭建/Hello World/打包exe

文章目录 Electron安装Node.jsNodeJs推荐配置开始Electron项目创建index.js文件创建src目录运行打包生成exe生成安装包踩坑 下一篇Electron实战(二)&#xff1a;将Node.js和UI能力&#xff08;app/BrowserWindow/dialog)等注入html Electron Electron是一个使用JavaScript, HT…

Java并发(二十三)----同步模式之保护性暂停

1、定义 即 Guarded Suspension&#xff0c;用在一个线程等待另一个线程的执行结果 要点 有一个结果需要从一个线程传递到另一个线程&#xff0c;让他们关联同一个 GuardedObject 如果有结果不断从一个线程到另一个线程那么可以使用消息队列 JDK 中&#xff0c;join 的实现…

LFU缓存(Leetcode460)

例题&#xff1a; 分析&#xff1a; 这道题可以用两个哈希表来实现&#xff0c;一个hash表&#xff08;kvMap&#xff09;用来存储节点&#xff0c;另一个hash表&#xff08;freqMap&#xff09;用来存储双向链表&#xff0c;链表的头节点代表最近使用的元素&#xff0c;离头节…

近期作业总结(函数,递归,二进制)

二分查找函数 写一个二分查找函数 功能&#xff1a;在一个升序数组中查找指定的数值&#xff0c;找到了就返回下标&#xff0c;找不到就返回-1。 int bin_search(int arr[], int left, int right, int key) {int mid 0;while (left < right) {mid (right left) / 2;if…

Transformer 自然语言处理(一)

原文&#xff1a;Natural Language Processing with Transformers 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 前言 当你阅读这些文字时&#xff0c;一个奇迹正在发生&#xff1a;这页上的涂鸦正在在你的大脑皮层中转化为单词、概念和情感。我的 2021 年 11 月的思…

django微博热搜数据分析与可视化系统python毕业设计

简而言之&#xff0c;数据可视化是以图形方式呈现结构化或非结构化数据&#xff0c;从而将隐藏在数据中的信息直接呈现给人们。但是有一个陷阱:它不仅仅是使用数据可视化工具将数据转化为图形。相反&#xff0c;它是从数据的角度看待世界。换句话说&#xff0c;数据可视化的对象…

cherles抓包,安卓,http/https

前置条件&#xff1a;charles抓取手机数据包的前提&#xff0c;手机和电脑需要在一个局域网内。 1、charles官网下载地址 Download a Free Trial of Charles • Charles Web Debugging Proxy 下载以后按提示安装即可。 2、charles的配置 在charles中【proxy->proxy Set…

Zabbix“专家坐诊”第225期问答汇总

来源&#xff1a;乐维社区 问题一 Q&#xff1a;当系统负荷顶不住时&#xff0c;比如4个cpu&#xff0c;load average 特别高&#xff0c;比如100。这时候这段时间zabbix的所有指标数据会丢失&#xff0c;不知道原因是什么&#xff0c;有没有办法去处理&#xff0c;保存这块指标…