【JavaScript】文档对象模型(DOM)的基本概念

文章目录

    • 1. 什么是DOM
    • 2. DOM的层次结构
    • 3. 获取DOM元素
      • 通过标签名获取元素
      • 通过ID获取元素
      • 通过类名获取元素
    • 4. 操作DOM元素
      • 修改元素内容
      • 修改元素样式
      • 添加新元素
    • 5. 事件处理
    • 6. 总结

文档对象模型(DOM)是 JavaScript 中一个重要的概念, 它允许开发者通过脚本语言操作 HTML 和 XML 文档的结构。本篇博客将介绍 DOM 的基本概念,帮助你更好地理解和应用这一重要的 Web 开发工具。

1. 什么是DOM

DOM 是一种用于表示和操作文档结构的树状模型。它将 HTML 或 XML 文档中的每个元素、属性、文本等都视为一个对象,通过这些对象,你可以使用 JavaScript 来操纵文档的内容、结构和样式。

2. DOM的层次结构

DOM 以树状结构表示文档,树的根节点是文档节点,文档节点包含了整个文档。文档节点的子节点可以是元素节点、文本节点、注释节点等。

<!DOCTYPE html>
<html><head><title>DOM Basics</title></head><body><h1>你好, DOM!</h1><p>这是一段落</p></body>
</html>

在上述例子中,文档节点是 html 元素,它有两个子节点 head 和 body。而 body 元素又包含两个子节点 h1 和 p

3. 获取DOM元素

在 JavaScript 中,你可以通过多种方式获取 DOM 元素,最常用的方法是通过标签名、ID、类名等。

通过标签名获取元素

let paragraphs = document.getElementsByTagName("p");

在上述例子中,通过 getElementsByTagName 方法获取了所有 p 元素,返回一个 HTMLCollection 对象。

通过ID获取元素

let heading = document.getElementById("myHeading");

在上述例子中,通过 getElementById 方法获取了 ID 为 myHeading 的元素。

通过类名获取元素

let elements = document.getElementsByClassName("myClass");

在上述例子中,通过 getElementsByClassName 方法获取了所有具有类名 myClass 的元素。

4. 操作DOM元素

修改元素内容

heading.innerHTML = "New Heading";

在上述例子中,通过 innerHTML 属性修改了元素的内容。

修改元素样式

paragraphs[0].style.color = "blue";

在上述例子中,通过 style 属性修改了第一个段落的文本颜色。

添加新元素

let newParagraph = document.createElement("p");
newParagraph.innerHTML = "This is a new paragraph.";
document.body.appendChild(newParagraph);

在上述例子中,通过 createElement 方法创建了一个新的 p 元素,并通过 appendChild 方法将它添加到文档的 body 中。

5. 事件处理

DOM 也提供了处理用户交互的能力,通过事件(如点击、鼠标移动等)可以触发 JavaScript 代码的执行。

document.getElementById("myButton").addEventListener("click", function() {alert("Button Clicked!");
});

在上述例子中,通过 addEventListener 方法给 ID 为 myButton 的按钮元素添加了一个点击事件的监听器。

6. 总结

文档对象模型(DOM)是 JavaScript 中用于操作 HTML 和 XML 文档的重要概念。它以树状结构表示文档的层次关系,通过提供各种方法和属性,使开发者能够轻松地获取、修改和创建文档中的元素。DOM 也支持事件处理,使得用户交互可以通过 JavaScript 来响应和控制。希望通过本篇博客,你对 DOM 的基本概念有了更深入的理解。

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

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

相关文章

【ECMAScript modules规范示例详解——介绍】

ECMAScript modules规范示例详解——介绍 1. 介绍2. 创建一个模块&#xff08;module.js&#xff09;3. 导入模块&#xff08;main.js&#xff09;4. 说明 1. 介绍 ECMAScript 模块 (ESM) 是 JavaScript 的官方标准&#xff0c;用于在 JavaScript 应用程序中导入和导出模块&am…

ChatGPT 4:新特性与优势

ChatGPT 4&#xff1a;新特性与优势 一、引言 ChatGPT 4是一款备受瞩目的人工智能模型&#xff0c;它以其强大的语言生成能力和智能回答能力&#xff0c;为用户提供了更高效、更便捷的对话体验。为了能够充分享受ChatGPT 4的各项功能&#xff0c;本文将向您详细介绍其新特性&…

Ps:信息面板

Ps菜单&#xff1a;窗口/信息 Window/Info 快捷键&#xff1a;F8 信息 Info面板提供了关于工作文档和当前操作的实时信息&#xff0c;包括鼠标指针的位置、取样点的颜色值&#xff08;包括调整前后的对比值&#xff09;&#xff0c;以及当前所用工具的提示信息等等&#xff0c;…

PyTorch深度学习实战(26)——多对象实例分割

PyTorch深度学习实战&#xff08;26&#xff09;——多对象实例分割 0. 前言1. 获取并准备数据2. 使用 Detectron2 训练实例分割模型3. 对新图像进行推断小结系列链接 0. 前言 我们已经学习了多种图像分割算法&#xff0c;在本节中&#xff0c;我们将学习如何使用 Detectron2 …

GPT最新进展:推出视频功能!迭代即将来临!

随着人工智能的不断进步&#xff0c;ChatGPT正准备以其全新的视频功能大跃进&#xff0c;同时&#xff0c;备受期待的GPT-5也即将在今年露面&#xff0c;预示着AI领域即将迎来一场变革。 在最近一期充满激情的Unconfuse Me播客中&#xff0c;OpenAI的首席执行官Sam Altman与技…

【前端高频面试题--Vue基础篇】

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;前端高频面试题 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac;前端高频面试题--Vue基础篇 Vue基本原理双向绑定与MVVM模型Vue的优点计算属性与监听属性计算属性监…

C 练习实例69-约瑟夫环

题目&#xff1a;有n个人围成一圈&#xff0c;顺序排号。从第一个人开始报数&#xff08;从1到3报数&#xff09;&#xff0c;凡报到3的人退出圈子&#xff0c;问最后留下的是原来第几号的那位。 代码&#xff1a; #include <stdio.h> int main() {int n8;int table[n]…

【MySQL】-19 MySQL综合-5(MySQL日期和时间类型+MySQL字符串类型+MySQL二进制类型)

MySQL日期和时间类型MySQL字符串类型MySQL二进制类型 一 MySQL 日期和时间类型1.1 YEAR 类型1.2 TIME 类型1.3 DATE 类型1.4 DATETIME 类型1.5 TIMESTAMP 类型 二 MySQL 字符串类型2.1 CHAR 和 VARCHAR 类型2.2 TEXT 类型2.3 ENUM 类型12.4 SET 类型 三 MySQL 二进制类型BIT 类…

python+flask+django医院预约挂号病历分时段管理系统snsj0

技术栈 后端&#xff1a;python 前端&#xff1a;vue.jselementui 框架&#xff1a;django/flask Python版本&#xff1a;python3.7 数据库&#xff1a;mysql5.7 数据库工具&#xff1a;Navicat 开发软件&#xff1a;PyCharm . 第一&#xff0c;研究分析python技术&#xff0c…

python32-Python列表和元组之通过索引使用元素

列表和元组非常相似&#xff0c;它们都可包含多个元素&#xff0c;多个元素也有各自的索引。程序可通过索引来操作这些元素&#xff0c;只要不涉及改变元素的操作&#xff0c;列表和元组的用法是通用的。 1&#xff09;通过索引使用元素 列表和元组都可通过索引来访问元素&am…

浅谈人工智能之深度学习~

目录 前言&#xff1a;深度学习的进展 一&#xff1a;深度学习的基本原理和算法 二&#xff1a;深度学习的应用实例 三&#xff1a;深度学习的挑战和未来发展方向 四&#xff1a;深度学习与机器学习的关系 五&#xff1a;深度学习与人类的智能交互 悟已往之不谏&#xff0…

模拟发送 Ctrl+Alt+Del 快捷键

目录 前言 一、在 XP 系统上模拟 SAS 二、在不低于 Vista 的系统上模拟 SAS 2.1 一些细节 2.2 实现原理和应用 三、完整实现代码和测试 3.1 客户端控制台程序 3.2 服务程序 3.3 编译&测试程序 四、总结&更新 参考文献 前言 对于开启了安全登陆的窗口工作站…

nodejs爬虫框架

nodejs爬虫框架 在Node.js中&#xff0c;有一些常用的爬虫框架可以帮助你实现网页抓取和数据提取的任务。以下是几个流行的Node.js爬虫框架&#xff1a; 1. **Puppeteer**: Puppeteer 是由 Google 开发的一个用于控制 headless Chrome 或 Chromium 浏览器的 Node.js 库。它提供…

保护你的 Linux VPS:入门指南

简介 掌控自己的 Linux 服务器是一个尝试新事物并利用强大平台的机会。然而&#xff0c;Linux 服务器管理员必须像对待任何网络连接的机器一样谨慎&#xff0c;以保持其安全性和稳定性。 有许多不同的安全主题属于“Linux 安全”这一总类&#xff0c;并且对于 Linux 服务器的适…

python-产品篇-游戏-玛丽冒险

文章目录 开发环境要求运行方法代码效果 开发环境要求 本系统的软件开发及运行环境具体如下。 &#xff08;1&#xff09;操作系统&#xff1a;Windows 7、Windows 8、Windows 10。 &#xff08;2&#xff09;Python版本&#xff1a;Python 3.7.0。 &#xff08;3&#xff09;…

Packet Tracer - Configure IOS Intrusion Prevention System (IPS) Using the CLI

Packet Tracer - 使用CLI配置IOS入侵防御系统&#xff08;IPS&#xff09; 地址表 目标 启用IOS入侵防御系统&#xff08;IPS&#xff09;。 配置日志记录功能。 修改IPS签名规则。 验证IPS配置。 背景/场景 您的任务是在R1上启用IPS&#xff0c;扫描进入192.168.1.0网络…

机器学习案例2:使用 plaidML在 macOS利用GPU进行机器学习

想要在 Mac 的集成 AMD GPU 或外部显卡上训练机器学习模型? PlaidML 就是您的最佳选择。 任何尝试过在 macOS 上使用 TensorFlow 训练神经网络的人都知道这个过程有点糟糕。 TensorFlow 只能利用 Mac 上的 CPU,因为 GPU 加速训练需要 Nvidia 芯片组。大多数大型模型在 CPU 上…

Matplotlib核心:掌握Figure与Axes

详细介绍Figure和Axes&#xff08;基于Matplotlib&#xff09; &#x1f335;文章目录&#x1f335; &#x1f333;引言&#x1f333;&#x1f333; 一、Figure&#xff08;图形&#xff09;&#x1f333;&#x1f341;1. 创建Figure&#x1f341;&#x1f341;2. 添加Axes&am…

React 常用 Hooks

React 常用 Hooks 简介 React Hooks 是 React 16.8 中引入的一项功能&#xff0c;它允许你在不编写 class 的情况下使用 state 和其他 React 特性。Hooks 的出现极大地简化了函数组件的状态管理和副作用的处理。本文将介绍几个最常用的 Hooks&#xff0c;并提供简洁明了的示例…

四.Linux实用操作 12-14.环境变量文件的上传和下载压缩和解压

目录 四.Linux实用操作 12.环境变量 环境变量 环境变量--PATH $ 符号 自行设置环境变量 自定义环境变量PATH 总结 四.Linux实用操作 13.文件的上传和下载 上传&#xff0c;下载 rz&#xff0c;sz命令 四.Linux实用操作 14.压缩和解压 压缩格式 tar命令 tar命令压缩…