深入理解 HTML DOM:文档对象模型详解

在前端开发中,HTML DOM(文档对象模型,Document Object Model)是一个非常重要的概念。它是浏览器将 HTML 文档解析为一个树形结构的方式,开发者可以通过 JavaScript 动态地访问和操作文档的内容、结构和样式。本文将详细介绍 HTML DOM 的核心概念、功能以及实际应用。


1. 什么是 HTML DOM?

HTML DOM 是浏览器将 HTML 文档解析为一个树形结构的编程接口。它将文档中的每个部分(如元素、属性、文本等)表示为节点(Node),这些节点共同组成了 DOM 树。通过 DOM,开发者可以使用 JavaScript 动态地操作网页内容。

DOM 树的结构

DOM 树由多个节点组成,常见的节点类型包括:

  • 文档节点(Document):整个文档的根节点。
  • 元素节点(Element):HTML 标签(如 <div><p> 等)。
  • 属性节点(Attribute):HTML 元素的属性(如 classid 等)。
  • 文本节点(Text):元素中的文本内容。
  • 注释节点(Comment):HTML 文档中的注释。

例如,以下 HTML 代码:

<!DOCTYPE html>
<html>
<head><title>DOM 示例</title>
</head>
<body><h1>Hello, DOM!</h1><p>这是一个段落。</p>
</body>
</html>

对应的 DOM 树结构如下:

Document
├── html
│   ├── head
│   │   └── title
│   │       └── "DOM 示例"
│   └── body
│       ├── h1
│       │   └── "Hello, DOM!"
│       └── p
│           └── "这是一个段落。"

2. DOM 的核心功能

DOM 提供了丰富的 API,允许开发者通过 JavaScript 操作文档。以下是 DOM 的核心功能:

2.1 访问元素

  • document.getElementById(id):通过元素的 ID 获取元素。
  • document.getElementsByClassName(className):通过类名获取元素集合。
  • document.getElementsByTagName(tagName):通过标签名获取元素集合。
  • document.querySelector(selector):通过 CSS 选择器获取第一个匹配的元素。
  • document.querySelectorAll(selector):通过 CSS 选择器获取所有匹配的元素。

示例:

// 获取 ID 为 "header" 的元素
const header = document.getElementById("header");// 获取所有类名为 "item" 的元素
const items = document.getElementsByClassName("item");// 获取第一个 <p> 元素
const firstParagraph = document.querySelector("p");// 获取所有 <p> 元素
const allParagraphs = document.querySelectorAll("p");

2.2 修改内容

  • element.innerHTML:获取或设置元素的 HTML 内容。
  • element.textContent:获取或设置元素的文本内容。
  • element.setAttribute(name, value):设置元素的属性。
  • element.getAttribute(name):获取元素的属性值。

示例:

// 修改元素的 HTML 内容
document.getElementById("content").innerHTML = "<p>新的内容</p>";// 修改元素的文本内容
document.querySelector("h1").textContent = "新的标题";// 设置元素的属性
document.querySelector("img").setAttribute("src", "new-image.jpg");// 获取元素的属性值
const src = document.querySelector("img").getAttribute("src");

2.3 修改样式

  • element.style.property = value:直接修改元素的样式。
  • element.classList.add(className):添加类名。
  • element.classList.remove(className):移除类名。
  • element.classList.toggle(className):切换类名。

示例:

// 修改元素的样式
document.querySelector("h1").style.color = "red";// 添加类名
document.querySelector("div").classList.add("active");// 移除类名
document.querySelector("div").classList.remove("inactive");// 切换类名
document.querySelector("button").classList.toggle("highlight");

2.4 添加和删除元素

  • document.createElement(tagName):创建新元素。
  • parentElement.appendChild(newElement):将新元素添加到父元素中。
  • parentElement.removeChild(childElement):从父元素中移除子元素。

示例:

// 创建一个新的 <p> 元素
const newParagraph = document.createElement("p");
newParagraph.textContent = "这是一个新的段落。";// 将新元素添加到 body 中
document.body.appendChild(newParagraph);// 移除元素
const oldParagraph = document.querySelector("p");
document.body.removeChild(oldParagraph);

2.5 事件处理

  • element.addEventListener(event, handler):为元素添加事件监听器。
  • element.removeEventListener(event, handler):移除事件监听器。

示例:

// 为按钮添加点击事件
document.querySelector("button").addEventListener("click", function() {alert("按钮被点击了!");
});

3. DOM 事件

DOM 事件是用户与网页交互时触发的动作,常见的事件包括:

  • click:点击事件。
  • mouseover:鼠标悬停事件。
  • keydown:键盘按下事件。
  • load:页面加载完成事件。

示例:

// 为按钮添加点击事件
document.querySelector("button").addEventListener("click", function() {alert("按钮被点击了!");
});

4. DOM 的优缺点

优点

  • 提供了强大的文档操作能力。
  • 支持动态更新页面内容。
  • 跨浏览器兼容性较好。

缺点

  • 操作 DOM 可能影响性能,尤其是在频繁更新时。
  • 复杂的 DOM 操作可能导致代码难以维护。

5. 实际应用

DOM 是前端开发的核心技术之一,常用于以下场景:

  • 动态更新页面内容(如 AJAX 请求后更新数据)。
  • 表单验证和交互。
  • 创建单页应用(SPA)。
  • 实现动画效果。

6. 总结

HTML DOM 是前端开发中不可或缺的一部分,它为我们提供了强大的文档操作能力。通过掌握 DOM,开发者可以创建更加动态和交互性强的网页应用。希望本文能帮助你更好地理解和使用 HTML DOM!

如果你对 DOM 还有其他疑问,欢迎在评论区留言讨论!


推荐阅读:

  • JavaScript 入门指南
  • 前端性能优化技巧

关注我,获取更多前端开发干货!

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

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

相关文章

unity学习21:Application类与文件存储的位置

目录 1 unity是一个跨平台的引擎 1.1 使用 Application类&#xff0c;去读写文件 1.2 路径特点 1.2.1 相对位置/相对路径&#xff1a; 1.2.2 固定位置/绝对路径&#xff1a; 1.3 测试方法&#xff0c;仍然挂一个C#脚本在gb上 2 游戏数据文件夹路径&#xff08;只读&…

【Redis】hash 类型的介绍和常用命令

1. 介绍 Redis 中存储的 key-value 本身就是哈希表的结构&#xff0c;存储的 value 也可以是一个哈希表的结构 这里每一个 key 对应的一个 哈希类型用 field-value 来表示 2. 常用命令 命令 介绍 时间复杂度 hset key field value 用于设置哈希表 key 中字段 field 的值为…

基于51单片机和WS2812B彩色灯带的流水灯

目录 系列文章目录前言一、效果展示二、原理分析三、各模块代码四、主函数总结 系列文章目录 前言 用彩色灯带按自己想法DIY一条流水灯&#xff0c;谁不喜欢呢&#xff1f; 所用单片机&#xff1a;STC15W204S &#xff08;也可以用其他1T单片机&#xff0c;例如&#xff0c;S…

力扣017_最小覆盖字串题解----C++

题目描述 我们可以用滑动窗口的思想解决这个问题。在滑动窗口类型的问题中都会有两个指针&#xff0c;一个用于「延伸」现有窗口的 r 指针&#xff0c;和一个用于「收缩」窗口的 l 指针。在任意时刻&#xff0c;只有一个指针运动&#xff0c;而另一个保持静止。我们在 s 上滑动…

如何从客观角度批判性阅读分析博客

此文仅以个人博客为例&#xff0c;大量阅读朋友反馈给我的交流让我得知他们所理解我的博客所表达的意思并非我所想表达的&#xff0c;差异或大或小&#xff0c;因人而异。 观点与事实 只有从客观角度反复批判性阅读和分析&#xff0c;才能逐渐清晰观点和事实。 观点不等于事实…

深入理解MySQL 的 索引

索引是一种用来快速检索数据的一种结构, 索引使用的好不好关系到对应的数据库性能方面, 这篇文章我们就来详细的介绍一下数据库的索引。 1. 页面的大小: B 树索引是一种 Key-Value 结构&#xff0c;通过 Key 可以快速查找到对应的 Value。B 树索引由根页面&#xff08;Root&am…

Spring Boot项目如何使用MyBatis实现分页查询及其相关原理

写在前面&#xff1a;大家好&#xff01;我是晴空๓。如果博客中有不足或者的错误的地方欢迎在评论区或者私信我指正&#xff0c;感谢大家的不吝赐教。我的唯一博客更新地址是&#xff1a;https://ac-fun.blog.csdn.net/。非常感谢大家的支持。一起加油&#xff0c;冲鸭&#x…

LabVIEW温度修正部件测试系统

LabVIEW温度修正部件测试系统 这个基于LabVIEW的温度修正部件测试系统旨在解决飞行器温度测量及修正电路的测试需求。该系统的意义在于提供一个可靠的测试平台&#xff0c;用于评估温度修正部件在实际飞行器环境中的性能表现&#xff0c;从而确保飞行器的安全性和可靠性。 系统…

动态规划每日一练(四)

一、day1——最长数对链 题目链接&#xff1a; 646. 最长数对链 - 力扣&#xff08;LeetCode&#xff09;646. 最长数对链 - 给你一个由 n 个数对组成的数对数组 pairs &#xff0c;其中 pairs[i] [lefti, righti] 且 lefti < righti 。现在&#xff0c;我们定义一种 跟随…

对比category_encoders库和sklearn库中的OrdinalEncoder

OrdinalEncoder 是用来对数据中的分类特征进行编码、转换为整数标签的函数。 category_encoders库 from category_encoders import OrdinalEncoder 安装&#xff1a;pip install category_encoders --trusted-host pypi.tuna.tsinghua.edu.cn&#xff08;记得关闭代理&#x…

【PLL】杂散生成和调制

时钟生成 --》 数字系统 --》峰值抖动频率生成 --》无线系统 --》 频谱纯度、 周期信号的相位不确定性 随机抖动&#xff08;random jitter, RJ&#xff09;确定性抖动&#xff08;deterministic jitter,DJ&#xff09; 时域频域随机抖动积分相位噪声确定性抖动边带 杂散生成和…

理解神经网络:Brain.js 背后的核心思想

温馨提示 这篇文章篇幅较长,主要是为后续内容做铺垫和说明。如果你觉得文字太多,可以: 先收藏,等后面文章遇到不懂的地方再回来查阅。直接跳读,重点关注加粗或高亮的部分。放心,这种“文字轰炸”不会常有的,哈哈~ 感谢你的耐心阅读!😊 欢迎来到 brain.js 的学习之旅!…

Ubuntu下的Doxygen+VScode实现C/C++接口文档自动生成

Ubuntu下的DoxygenVScode实现C/C接口文档自动生成 Chapter1 Ubuntu下的DoxygenVScode实现C/C接口文档自动生成1、 Doxygen简介1. 安装Doxygen1&#xff09;方法一&#xff1a;2&#xff09;方法二&#xff1a;2. doxygen注释自动生成插件3. doxygen注释基本语法4. doxygen的生成…

Java内存模型 volatile 线程安全

专栏系列文章地址&#xff1a;https://blog.csdn.net/qq_26437925/article/details/145290162 本文目标&#xff1a; 认识JMM认识volatile关键字&#xff1a;可见性和顺序性理解线程安全的概念 目录 Java内存模型可见性例子和volatilevolatile如何保证可见性原子性与单例模式…

【Proteus仿真】【51单片机】多功能计算器系统设计

目录 一、主要功能 二、使用步骤 三、硬件资源 四、软件设计 五、实验现象 联系作者 一、主要功能 1、LCD1602液晶显示 2、矩阵按键​ 3、加减乘除&#xff0c;开方运算 4、带符号运算 5、最大 999*999 二、使用步骤 基于51单片机多功能计算器 包含&#xff1a;程序&…

three.js+WebGL踩坑经验合集(4.1):THREE.Line2的射线检测问题(注意本篇说的是Line2,同样也不是阈值方面的问题)

上篇大家消化得如何了&#xff1f; 笔者说过&#xff0c;1级编号不同的两篇博文相对独立&#xff0c;所以这里笔者还是先给出完整代码&#xff0c;哪怕跟&#xff08;3&#xff09;没有太大区别。 这里我们把线的粗细调成5&#xff08;排除难选中的因素&#xff09;&#xff…

SAP内向交货单详解

【SAP系统研究】 #SAP #交货单 #内向交货单 一、内向交货单的概念 内向交货单,Inbound Delivery,是SAP系统中用于管理外部供应商或内部工厂向公司发货的文档。它记录了货物从供应商到公司仓库或生产地点的运输和接收过程。 内向交货单的主要功能有: (1)货物接收:用于…

扩展无限可能:Obsidian Web Viewer插件解析

随着 Obsidian 1.8.3 正式版的发布&#xff0c;备受期待的官方核心插件——Web Viewer 也终于上线。本文将从插件启用、设置以及应用场景三个方面详细介绍如何使用这一新功能&#xff0c;和大家一起更好地利用 Obsidian 进行内容管理和知识整理。 插件启用 Web Viewer作为官方…

如何在 ACP 中建模复合罐

概括 本篇博文介绍了 ANSYS Composite PrepPost (ACP) 缠绕向导。此工具允许仅使用几个条目自动定义高压罐中常见的悬垂复合结构。 ACP 绕线向导 将必要的信息输入到绕组向导中。重要的是要注意“参考半径”&#xff0c;它代表圆柱截面的半径&#xff0c;以及“轴向”&#x…

本地搭建deepseek-r1

一、下载ollama(官网下载比较慢&#xff0c;可以找个网盘资源下) 二、安装ollama 三、打开cmd&#xff0c;拉取模型deepseek-r1:14b(根据显存大小选择模型大小&#xff09; ollama pull deepseek-r1:14b 四、运行模型 ollama run deepseek-r1:14b 五、使用网页api访问&#x…