”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > HTMLCollections、NodeLists 和对象数组在 DOM 操作中有何不同?

HTMLCollections、NodeLists 和对象数组在 DOM 操作中有何不同?

发布于2024-11-10
浏览:955

How do HTMLCollections, NodeLists, and Object Arrays Differ in DOM Manipulation?

区分 DOM 中的 HTMLCollections、NodeList 和 Object Arrays

开发者在访问 DOM 节点时,经常会遇到 HTMLCollections、NodeLists 和对象数组。了解这些数据结构之间的差异对于有效操作文档结构至关重要。

HTMLCollections 与 NodeLists

HTMLCollections 和 NodeLists 与节点集合有相似之处,但它们有显着特征:

  • 内容: HTMLCollections 只包含 Element 节点,而 NodeLists 可以容纳任何类型的节点。
  • 方法: In除了所有集合通用的方法之外,HTMLCollections 还提供namedItem 方法用于按名称访问元素。

实时集合与快照集合

DOM 集合可以是实时或快照:

  • 实时: 当对 DOM 进行更改时,集合会自动更新。
  • 快照: 集合保持固定,无论 DOM 修改如何。

浏览器方法(例如 getElementsByTagName)返回的 DOM 集合通常是实时的,而 jQuery 选择是快照。

数组与对象数组

虽然 jQuery 对象在控制台日志中显示为数组,但它们实际上是对象数组:

  • 数组: 使用数字索引访问的顺序集合。
  • 对象数组: 使用数字和命名属性访问元素的数组。

选择节点

使用文档方法:

  • document.getElementsByTagName("td"):返回所有 td 元素的 HTMLCollection。
  • document.getElementsByClassName("myRow"):返回具有“myRow”类的所有元素的 NodeList。

使用 jQuery:

  • $("td"): 选择所有 td 元素并返回一个 jQuery 对象,一个对象数组。

示例脚本

提供的脚本演示了数据结构之间的差异:

  • console.log('[123,"abc",321,"cba"]=[123,"abc",321,"cba"]: 比较数组。
  • console.log('{ 123:123,abc:"abc",321:321,cba:"cba"}={123:123,abc:"abc",321:321,cba:"cba"}:将对象数组与对象语法进行比较。
  • console.log('Node=',Node):记录全局Node对象,它是一个代表节点类型的对象数组。
  • console.log('document.links=', document.links): 记录链接的 HTMLCollection。
  • console.log('document.getElementById("myTable")=',document.getElementById("myTable")): 记录单个元素,而不是collection.
  • console.log('document.getElementsByClassName("myRow")=',document.getElementsByClassName("myRow")): 记录具有“myRow”类的元素的 NodeList。
  • console.log('document.getElementsByTagName("td")=',document.getElementsByTagName("td")): 记录所有 td 元素的 HTMLCollection。
  • console.log('$(" #myTable")=',$("#myTable")): 记录表示 #myTable 元素的 jQuery 对象。
  • console.log('$("td")=',$("td ")):记录包含所有 td 元素的 jQuery 对象数组。
最新教程 更多>
  • Java中线程引用设置为Null时会产生垃圾吗?
    Java中线程引用设置为Null时会产生垃圾吗?
    Java 线程:垃圾收集与否?在此 Java 代码片段中,创建了一个新线程,并使用 t.start( )。但是,启动线程后,线程引用 t 被设置为 null,且 t = null。这就提出了一个问题:在没有主动引用线程的情况下,线程是否会被垃圾收集。Java 中的垃圾收集当垃圾收集器在 Java 中...
    编程 发布于2024-11-18
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-11-18
  • 为什么我的 Python MySQL 插入不起作用?
    为什么我的 Python MySQL 插入不起作用?
    Python MySQL 插入操作疑难解答在 Python 中,使用 MySQL API 与 MySQL 数据库交互,插入记录可能会遇到障碍。本文解决了这样一个问题:尽管实现看似正确,但记录却无法插入。提供的代码建立了与数据库的连接,并尝试将记录插入“文档”表中。但是,插入操作失败。要解决这个问题,...
    编程 发布于2024-11-18
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-18
  • 为什么 C++ 构造函数有两个符号?
    为什么 C++ 构造函数有两个符号?
    C 构造函数的双重符号Itanium C ABI 指定构造函数的重整名称包含有关其类型和参数的信息。因此,在库中观察到的两个构造函数条目源于它们不同的构造函数类型:完整对象构造函数(C1):此构造函数完全初始化对象,包括任何虚拟基类.基础对象构造函数 (C2): 此构造函数初始化对象本身以及数据成员...
    编程 发布于2024-11-18
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-18
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-18
  • WaitGroup.Wait() 返回后检查共享变量是否安全?
    WaitGroup.Wait() 返回后检查共享变量是否安全?
    WaitGroup.Wait() 和内存屏障在访问共享变量的多线程环境中,强制同步至关重要以防止出现意外结果。 Go 中的一种此类机制是“sync.WaitGroup”包,它有助于管理并发运行的 goroutine。当前的问题围绕“WaitGroup.Wait()”和内存屏障之间的关系展开具体代码片...
    编程 发布于2024-11-18
  • 在 C++ 中如何将浮点数精确转换为具有指定十进制精度的字符串?
    在 C++ 中如何将浮点数精确转换为具有指定十进制精度的字符串?
    将浮点数精确转换为具有指定十进制精度的字符串在 C 中,将浮点数转换为具有特定精度的字符串,并且小数位需要仔细考虑。本指南探讨了两种常见的解决方案:stringstream 和 C 17 中的 to_chars 函数。使用 StringstreamStringstream 是用于在 C 中操作字符串...
    编程 发布于2024-11-18
  • \“需要帮助修改默认日历选择器的 UI\”
    \“需要帮助修改默认日历选择器的 UI\”
    嗨,团队,我在 AG 网格单元中使用日历,但我无法修改此日历的 UI,也无法检查它。我想更改日历的 UI。 请参阅链接以获取更多说明 https://www.ag-grid.com/examples/provided-cell-editors-date/date-editor/modules/typ...
    编程 发布于2024-11-18
  • 为什么我在 MySQL 中收到“写入文件‘/tmp/MY1fnqpm’时出错(错误代码:28)”?
    为什么我在 MySQL 中收到“写入文件‘/tmp/MY1fnqpm’时出错(错误代码:28)”?
    MySQL 文件写入错误(Errcode 28):诊断和解决遇到错误“Errorwriting file '/tmp/MY1fnqpm' (Errcode: 28)” 在 MySQL 查询中,根本原因通常在于可用磁盘空间不足。要确认这一点,请使用 perror 命令:$ perror...
    编程 发布于2024-11-18
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-18
  • 如何使用 Sequelize CLI 从 Sequelize 模型生成迁移?
    如何使用 Sequelize CLI 从 Sequelize 模型生成迁移?
    使用 Sequelize CLI 从 Sequelize 模型自动生成迁移人们可能拥有预先存在的 Sequelize 模型,但希望使用迁移而不是数据库同步。 Sequelize CLI 提供了一篇文章中概述的解决方案,其中指出,“当利用 CLI 进行模型生成时,您将自动获取必要的迁移脚本。”要实现此...
    编程 发布于2024-11-18
  • 为什么Selenium 2.53.0在使用Firefox 47时会遇到连接错误?
    为什么Selenium 2.53.0在使用Firefox 47时会遇到连接错误?
    Selenium 2.53 与 Firefox 47 不兼容使用 Selenium WebDriver 2.53.0 时,遇到错误:org.openqa.selenium.firefox.NotConnectedException: Unable to connect to host 127.0.0...
    编程 发布于2024-11-18

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3