js将类数组对象转换成数组对象

yizhihongxing

将类数组对象转换成数组是 JavaScript 中常见的操作,类数组对象通常具有数字索引以及 length 属性,但不具有数组的一些操作方法。下面是将类数组对象转换成数组对象的完整攻略。

方法一:使用 Array.from()

可以使用 Array.from() 方法将类数组对象转换成一个新的数组。Array.from() 接受一个类数组对象或可迭代对象,并返回一个新的数组。

const nodeList = document.querySelectorAll('div'); //获取 DOM 元素
const divArray = Array.from(nodeList);            //将 DOM 转换成数组
console.log(divArray);

上面的代码通过 document.querySelectorAll 获取到页面中所有的 div 元素,然后使用 Array.from() 方法将 NodeList 转换成数组。转换后,可以使用数组的各种方法来操作这个数组,比如使用 forEach() 遍历数组。

divArray.forEach(element => {
  console.log(element);
});

方法二:使用 Array.apply()

也可以使用 Array.prototype.slice.call() 或者 Function.prototype.call() 方法将类数组对象转换成数组,但这些方法实现起来相对繁琐。简单来说,就是通过借用数组 slice 方法,将数组的原型方法应用在类数组对象上,从而得到一个新的数组。

const nodeList = document.querySelectorAll('div'); //获取 DOM 元素
const divArray = Array.prototype.slice.call(nodeList);  //使用 slice 方法将 NodeList 转换成数组
console.log(divArray);

上面的代码同样是将 NodeList 转换成数组,并将转换后的数组打印到控制台中。这里借用了 slice 方法,并将其应用在 nodeList 上,作用与 Array.from() 相同。

以上就是两种将类数组对象转换成数组对象的方法及示例。这种操作在前端开发中非常常见,掌握这种技能对于前端开发人员来说是非常必要的。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:js将类数组对象转换成数组对象 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • 详解Javascript中DOM的范围

    详解Javascript中DOM的范围 什么是DOM范围 在Javascript中,DOM(Document Object Model)是指用来描述HTML文档结构的树形结构模型。而DOM范围则是指在Javascript中,我们可以对DOM树进行操作的范围。 一个DOM范围由以下几个组成部分: 起始边界点(start boundary point):范围的开…

    JavaScript 2023年6月10日
    00
  • 10行原生JS实现文字无缝滚动(超简单)

    当根据文章中提供的攻略,我们可以用不到十行的原生JS代码实现文字无缝滚动的效果。下面逐步解读这个攻略的实现过程: 第一步:获取DOM元素 首先,需要获取到需要滚动的文字所在的DOM元素。这可以通过document.querySelector()方法来获取。在示例中,需要滚动的文字是包含在一个<div>元素中的,其class为scroll-wrap…

    JavaScript 2023年6月11日
    00
  • xmlplus组件设计系列之路由(ViewStack)(7)

    《xmlplus组件设计系列之路由(ViewStack)(7)》是XMLPlus团队所编写关于ViewStack组件的一篇技术文章。该文章中详细介绍了如何设计ViewStack组件,并提供了示例代码和运行演示。下面是该文章的完整攻略: XMLPlus组件设计系列之路由(ViewStack)(7) 什么是ViewStack组件? ViewStack组件是一种可…

    JavaScript 2023年6月11日
    00
  • js Math 对象的方法

    当我们要对数字进行一些复杂的操作或计算时,js语言内置的 Math 对象是不可或缺的一个工具。Math 对象提供了很多有用的方法来处理数字。 常用方法 Math.abs() Math.abs() 方法用于返回给定数字的绝对值,即该数字距离 0 的距离,无论正负。 Math.abs(-5); // 返回 5 Math.abs(5); // 返回 5 Math.…

    JavaScript 2023年5月28日
    00
  • Java日常练习题,每天进步一点点(34)

    《Java日常练习题,每天进步一点点(34)》是一篇Java编程练习题目的博客文章。该文中提供了10个常见的Java编程问题,供读者进行练习,提高编程水平。以下是对于该文章的详细讲解攻略: 标题 标题使用 # 号,# 号的数量代表标题级数 需要在每个标题后面空一行 代码块 代码块使用 “` 或者缩进四个空格 代码块中的代码可以被正确地渲染 内容 内容中需要…

    JavaScript 2023年5月28日
    00
  • JS获取子、父、兄节点方法小结

    JS获取子、父、兄节点方法小结 在JavaScript中,我们经常需要获取某个元素的子元素、父元素或者兄弟元素来执行一些特定的操作。下面我们来总结一下JS获取子、父、兄节点的常用方法。 一、获取子节点 使用childNodes属性可以获取当前元素的所有子节点,包括文本节点、注释节点等。但是这个属性返回的是一个NodeList对象,如果想要获取指定位置的子元素…

    JavaScript 2023年6月10日
    00
  • 详解javascript中的事件处理

    详解JavaScript中的事件处理 什么是事件处理? 事件处理是指通过JavaScript来处理HTML或者DOM中的各种事件,例如用户点击按钮、提交表单、滚动网页等等。事件处理使得网页能够在用户交互过程中获得更好的响应和体验。 在HTML中添加事件处理 在HTML中添加事件处理是最简单的方式,我们可以使用on属性来给HTML元素添加事件处理函数。例如: …

    JavaScript 2023年5月18日
    00
  • 编写Ruby脚本来对Twitter用户的数据进行深度挖掘

    以下是编写Ruby脚本来对Twitter用户的数据进行深度挖掘的完整攻略及例子说明: 1. 创建Twitter应用程序 要对Twitter用户的数据进行挖掘,首先需要创建一个Twitter开发者账号,并创建一个Twitter应用程序。创建的过程如下: 登录https://developer.twitter.com/en/apps 点击”Create an a…

    JavaScript 2023年6月11日
    00
合作推广
合作推广
分享本页
返回顶部