HTML网页文档和DOM结构介绍

HTML网页文档和DOM结构介绍

HTML网页文档

HTML,全称为超文本标记语言(Hypertext Markup Language),是用来描述并定义内容结构的标记语言,它是构建任何网页和网络应用的最基础的组成部分。HTML文档由一系列的元素构成,这些元素通过标签(tags)的形式标记出不同类型的内容,比如段落、标题、列表、链接、图片等。

一个典型的HTML文档结构包括以下部分:

<!DOCTYPE html>:文档类型声明,告诉浏览器这是一个HTML5文档;

<html>:根元素,包含整个HTML文档;

<head>:头部分,包含文档的元数据,如标题、字符编码、样式表链接和脚本文件等;

<title>:定义文档的标题,显示在浏览器的标题栏或页面的标签上;

<body>:主体部分,包含实际显示在网页上的内容,如文本、图片、视频等。

一个简单的HTML文档例子:

<!DOCTYPE html>
<html>
<head>
    <title>我的网页</title>
</head>
<body>
    <h1>欢迎来到我的网页</h1>
    <p>这是一个段落。</p>
    <a href="https://www.example.com">访问我的链接</a>
</body>
</html>

DOM结构

DOM,全称为文档对象模型(Document Object Model),是一个跨平台和语言独立的接口,它将HTML文档结构化为一个树状结构。每个节点(Node)在这棵树中代表文档中的一个部分,比如元素、属性和文本内容。DOM 的最小组成单位叫做节点(node)。文档的树形结构(DOM 树),就是由各种不同类型的节点组成。

【W3C(World Wide Web Consortium:万维网联盟)提出的 DOM(文档对象模型)标准被分为三个不同的部分,每个部分针对不同类型的文档。

核心DOM:核心DOM定义了处理任何结构化文档的标准模型。它提供了用于创建、修改和操作文档的基本对象和方法,包括节点(node)、元素(element)、属性(attribute)等等。核心DOM适用于处理XML文档和HTML文档。

XML DOM:XML DOM是针对XML文档的标准模型。XML DOM继承和扩展了核心DOM,提供了处理XML文档的额外功能,提供了额外的功能来处理XML文档的特定特性,例如命名空间、CDATA节等。XML DOM提供了用于解析、遍历和操作XML文档的方法和属性。

HTML DOM:HTML DOM是针对HTML文档的标准模型。HTML DOM也是继承和扩展了核心DOM,提供了处理HTML文档的额外功能,添加了特定于HTML文档的功能。HTML DOM提供了访问和操作HTML文档的方法和属性,例如操作HTML元素、样式、表单、事件等等。

本文所说DOM是指HTML DOM。】

DOM使得开发人员能够使用JavaScript等脚本语言来访问和操作文档的内容、结构和样式。通过DOM API,可以动态地添加、删除或修改页面的元素和内容,实现丰富的交互效果。

HTML DOM (Document Object Model) 提供了一组 API,允许我们通过 JavaScript 对 HTML 文档进行操作。它将 HTML 文档表示为一个树形结构,每个元素、属性和文本都被视为一个节点(node)。

在HTML DOM中,节点(Node)类型包括以下几种:

    元素节点(Element Node):代表HTML元素,如<div>, <p>, <a>等。

    文本节点(Text Node):代表元素中的文本内容,通常是元素节点的子节点。

    属性节点(Attribute Node):代表元素的属性,如id、class等。

    注释节点(Comment Node):代表HTML文档中的注释,以<!-- -->包裹的内容。

    文档节点(Document Node):代表整个HTML文档。DOM 树结构的入口。

    文档类型节点(Document Type Node):代表文档类型声明(<!DOCTYPE>)。

    文档片段节点(Document Fragment Node):代表一个虚拟的DOM片段,通常用于临时存储一组节点。

节点之间的关系
DOM 节点树结构中,节点之间可以具有以下关系:
☆父子(Parent-Child)关系:一个节点可以拥有子节点,这些子节点称为该节点的子元素。子节点与父节点之间的关系称为父子关系,父节点是子节点的直接上级节点,而子节点是父节点的直接下级节点。
☆兄弟(Sibling)关系:同一个父节点下的子节点之间称为兄弟节点,它们在节点树结构中处于同一层级。
☆祖先后代(Ancestor-descendant)关系:一个节点的所有父节点以及祖先节点称为该节点的祖先节点,相对应的,一个节点的所有子节点以及后代节点称为该节点的后代节点。
例如:
假设有以下 HTML 结构:
Copy<!DOCTYPE html>
<html>
<head>
    <title>DOM节点关系示例</title>
</head>
<body>
    <div id="parent">
        <h1>This is a heading</h1>
        <p>This is a paragraph</p>
        <ul>
            <li>Item 1</li>
            <li>Item 2</li>
        </ul>
    </div>
</body>
</html>

在这个例子中,我们可以看到以下节点关系:
1."parent" 元素是整个文档的父级元素,它包含了所有其他元素。
2."h1"、"p"、"ul" 是 "parent" 元素的子元素,它们之间有父子关系。
3."li" 元素是 "ul" 元素的子元素,它们之间也有父子关系。
4."h1" 和 "p" 元素是兄弟节点,它们有相同的父节点 "parent"。
5."li" 元素也是兄弟节点,它们有相同的父节点 "ul"。】

以下是一个简化的对应上面的HTML例子的DOM树结构:

当浏览器加载并解析HTML页面时,会创建一个DOM(文档对象模型)树结构来表示页面的结构和内容。并且 DOM 树结构模型会被存储在浏览器的内存中。当DOM树结构发生变化(例如通过JavaScript添加或删除节点)时,浏览器会重新构建和更新DOM树,以反映最新的页面状态。

每个元素如<body>、<h1>和<a>都会成为DOM树中的一个节点,而文本内容如"欢迎来到我的网页"会成为文本节点。属性如href="https://www.example.com"则是元素节点的属性节点。

下面给出使用DOM操作上面HTML文档节点的例子,要求:

1、获取<h1>元素<h1>元素,并显示出来

2、将<a href="https://www.example.com">中的“href="https://www.example.com"”改为:“href="https://https://www.baidu.com/"”

源码如下:

<!DOCTYPE html>
<html>
<head>
    <title>我的网页</title>
</head>
<body>
    <h1>欢迎来到我的网页</h1>
    <p>这是一个段落。</p>
    <a href="https://www.example.com">访问我的链接</a>
    <script>
        // 1、获取<h1>元素
        var h1Element = document.querySelector('h1');
        // 显示<h1>元素的内容
        console.log("<h1>元素内容:" + h1Element.textContent);  //向控制台输出字符串消息
        //alert("<h1>元素内容:" + h1Element.textContent);  //弹窗输出框
        // 2、获取<a>元素
        var aElement = document.querySelector('a');
        // 修改<a>元素的href属性值
        aElement.setAttribute('href', 'https://www.baidu.com/');
    </script>
</body>
</html>

请留意其中<script>  </script>之间的部分。

这样能使得开发者可以编写脚本来实现网页的动态行为和内容更新。

DOM 对HTML 操作

通过 DOM,我们可以获取、修改、添加或删除 HTML 元素。换句话说,HTML DOM (Document Object Model) 提供了一组 API,允许我们通过 JavaScript 对 HTML 文档的节点进行操作。前面已涉及过,以下是关于这些操作更多介绍。

★获取 HTML 元素:

☆document.getElementById(id):通过元素的 id 属性获取元素。

☆document.getElementsByClassName(className):通过元素的 class 属性获取一组元素。

☆document.getElementsByTagName(tagName):通过元素的标签名获取一组元素。

☆document.querySelector(selector):通过 CSS 选择器获取第一个匹配的元素。

☆document.querySelectorAll(selector):通过 CSS 选择器获取所有匹配的元素。

★修改 HTML 元素:

☆element.innerHTML:获取或设置元素的 HTML 内容。

☆element.textContent:获取或设置元素的文本内容。

☆element.getAttribute(attributeName):获取元素的指定属性值。

☆element.setAttribute(attributeName, value):设置元素的指定属性值。

☆element.removeAttribute(attributeName):删除元素的指定属性。

☆element.style.property:获取或设置元素的样式属性。

☆element.classList.add(className):为元素添加一个 CSS 类。

☆element.classList.remove(className):从元素中删除一个 CSS 类。

☆element.classList.toggle(className):切换元素的 CSS 类。

★添加 HTML 元素:

☆document.createElement(tagName):创建一个新的元素节点。

☆parentElement.appendChild(newElement):将新元素添加到父元素的子节点列表的末尾。

☆parentElement.insertBefore(newElement, referenceElement):在参考元素之前插入新元素。

★删除 HTML 元素:

☆parentElement.removeChild(element):从父元素中删除指定的子元素。

☆element.remove():从 DOM 中删除元素自身。

★遍历 HTML 元素:

☆element.parentNode:获取元素的父节点。

☆element.childNodes:获取元素的所有子节点(包括文本节点)。

☆element.children:获取元素的所有子元素节点。

☆element.firstChild:获取元素的第一个子节点。

☆element.lastChild:获取元素的最后一个子节点。

☆element.nextSibling:获取元素的下一个兄弟节点。

☆element.previousSibling:获取元素的上一个兄弟节点。

★事件处理:

☆element.addEventListener(event, function):为元素添加事件监听器。

☆element.removeEventListener(event, function):从元素中移除事件监听器。

这些是 HTML DOM 操作的基本方法和属性。通过合适地使用它们,我们可以动态地获取、修改、添加或删除 HTML 元素,以及响应用户交互事件。

需要注意的是,在进行 DOM 操作时,要确保在文档加载完成后再进行操作,可以使用 window.onload 事件或将 JavaScript 代码放在 <body> 元素的末尾来确保这一点。

此外,还有一些其他的 DOM 方法和属性,如 cloneNode()、hasAttribute()、contains() 等,可以根据具体需求进一步探索和使用。

下面给出使用DOM操作HTML文档的示例。
★获取元素并修改其内容:
<div id="myDiv">Hello, World!</div>

<script>
  // 获取元素
  var myDiv = document.getElementById("myDiv");

  // 修改元素的文本内容
  myDiv.textContent = "Hello, DOM!";

  // 修改元素的 HTML 内容
  myDiv.innerHTML = "<strong>Hello, DOM!</strong>";
</script>

★获取元素并修改其样式:
<p id="myParagraph">This is a paragraph.</p>

<script>
  // 获取元素
  var myParagraph = document.getElementById("myParagraph");

  // 修改元素的样式
  myParagraph.style.color = "red";
  myParagraph.style.fontSize = "20px";
  myParagraph.style.fontWeight = "bold";
</script>

★获取多个元素并遍历修改:
<ul id="myList">
  <li>Item 1</li>
  <li>Item 2</li>
  <li>Item 3</li>
</ul>

<script>
  // 获取元素
  var myList = document.getElementById("myList");
  var listItems = myList.getElementsByTagName("li");

  // 遍历并修改元素
  for (var i = 0; i < listItems.length; i++) {
    listItems[i].textContent = "Modified Item " + (i + 1);
  }
</script>

★创建新元素并添加到文档中:
<div id="myContainer"></div>

<script>
  // 获取容器元素
  var myContainer = document.getElementById("myContainer");

  // 创建新元素
  var newParagraph = document.createElement("p");
  newParagraph.textContent = "This is a new paragraph.";

  // 将新元素添加到容器中
  myContainer.appendChild(newParagraph);
</script>

★删除元素:
<ul id="myList">
  <li>Item 1</li>
  <li id="itemToRemove">Item 2</li>
  <li>Item 3</li>
</ul>

<script>
  // 获取要删除的元素
  var itemToRemove = document.getElementById("itemToRemove");

  // 获取父元素
  var myList = itemToRemove.parentNode;

  // 从父元素中删除子元素
  myList.removeChild(itemToRemove);
</script>

★事件处理:
<button id="myButton">Click me!</button>

<script>
  // 获取按钮元素
  var myButton = document.getElementById("myButton");

  // 添加事件监听器
  myButton.addEventListener("click", function() {
    alert("Button clicked!");
  });
</script>

这些简单示例展示了如何使用 DOM 操作获取元素、修改元素内容和样式、创建新元素、删除元素以及处理事件。你可以根据具体需求组合使用这些操作,以实现对 HTML 文档的动态修改和交互。
 

附录

DOM 概述 DOM 概述 - Web API 接口参考 | MDN

HTML DOM 参考手册W3schools - 参考手册

JavaScript简介与实验基础 JavaScript简介与实验基础_javascript实验-CSDN博客

BOM和DOM入门(修订)BOM和DOM入门(修订)_bom和dom的结构关系示意图-CSDN博客

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

《由浅入深学习SAP财务》:第2章 总账模块 - 2.2 组织结构

在SAP的FI模块&#xff0c;主要的组织结构有公司代码&#xff08;一定会用&#xff09;、公司&#xff08;只在做合并业务时用&#xff09;、业务范围&#xff08;可能使用&#xff09;、段&#xff08;较少使用&#xff09;、利润中心&#xff08;可能使用&#xff09;。 2.2…

二叉树|257.二叉树的所有路径

力扣题目链接 class Solution { private:void traversal(TreeNode* cur, vector<int>& path, vector<string>& result) {path.push_back(cur->val); // 中&#xff0c;中为什么写在这里&#xff0c;因为最后一个节点也要加入到path中 // 这才到了叶子节…

ThingsBoard初始化数据库Postgres+Cassandra

本章将介绍ThingsBoard初始化数据PostgresCassandra&#xff0c;两种数据库结合使用&#xff0c;以及源码的编译安装。本机环境&#xff1a;Centos7、Docker、Postgres、Cassandra 环境安装 开发环境要求&#xff1a; docker &#xff1b;Docker&#xff1b;Postgres:Cassandr…

为车主提供多路况安全保障!“北欧轮胎安全专家”熊牌轮胎迎来全新升级

德国马牌轮胎旗下明星品牌——Gislaved熊牌轮胎迎来全新升级。 自进入中国市场以来&#xff0c;熊牌轮胎凭借着坚韧安全、静音降噪等特点&#xff0c;收获无数好评。此次全新升级的熊牌轮胎&#xff0c;在品牌logo中加入了“北欧棕熊”的形象&#xff0c;并且对此前轮胎标签中的…

哨兵位、链表的链接

哨兵位&#xff1a; 通俗的话讲就是额外开辟一块空间&#xff0c;指向链表的头部。 合并两个有序链表 已解答 简单 相关标签 相关企业 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例 1&#xff1a; 输入&#…

PID算法原理分析及优化

今天为大家介绍一下经典控制算法之一的PID控制方法。PID控制方法从提出至今已有百余年历史&#xff0c;其由于结构简单、易于实现、鲁棒性好、可靠性高等特点&#xff0c;在机电、冶金、机械、化工等行业中应用广泛。 在大学期间&#xff0c;参加的智能汽车竞赛中就使用到了PI…

1. Java基础入门

1. Java基础入门 1.1 Java介绍(了解) 1.1.1 Java背景 Java是美国 sun 公司&#xff08;Stanford University Network&#xff09;在1995年推出的一门计算机高级编程语言。Java 之父&#xff1a;詹姆斯高斯林(James Gosling)。 2009年 sun公司被Oracle公司收购。Java公司图标…

工业网关的功能与作用进行解析-天拓四方

在工业4.0和智能制造的时代背景下&#xff0c;工业网关作为连接现场设备与云端平台的桥梁&#xff0c;正发挥着日益重要的作用。它不仅为工业设备的远程监控和管理提供了可能&#xff0c;还为企业实现数字化转型和智能化升级提供了有力支持。本文将对工业网关的功能与作用进行解…

#Linux(权限管理)

&#xff08;一&#xff09;发行版&#xff1a;Ubuntu16.04.7 &#xff08;二&#xff09;记录&#xff1a; &#xff08;1&#xff09; &#xff08;2&#xff09;-开头代表普通文件 划分为三组&#xff1a; rw- rw- r-- rw-: 文件拥有…

使用远程工具连接Mysql

&#xff08;若想要远程连接Mysql需要下面解决四个问题&#xff09; 1、目标地址 直接查询 2、端口号 3306 3、防火墙关闭 [rootlocalhost date]# systemctl stop firewalld.service 4、授权mysql数据库root用户权限&#xff08;因为mysql开始不允许其他IP访问&#xff0…

.NET开源、免费、强大的交互式绘图库

前言 今天大姚给大家分享一款.NET开源&#xff08;采用MIT许可证&#xff09;、免费、强大的交互式绘图库&#xff0c;该库能够轻松地实现大型数据集的交互式显示。使用几行代码即可快速创建折线图、柱状图、饼图、散点图等不同类型的图表&#xff1a;ScottPlot。 ScottPlot类…

【博特激光】使用视觉激光打标机有哪些优势

​ 使用视觉激光打标机具有以下优势&#xff1a; 1. 高精度定位&#xff1a;视觉激光打标机采用先进的视觉识别技术&#xff0c;能够在极短的时间内对物体进行精准的检测和定位&#xff0c;实现打标点的位置精度高达0.01mm以上。这使得它能够满足各种高精度打标需求&#xff0…

Mysql---DML

文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 一.DML概述 DML&#xff08;Data Manipulation Language&#xff09;是MySQL中用于操作数据库中数据的语言。DML语句用于插入、更新和删除数据库中的记录&#xff0c;以及查询和修改数据库中的数…

RabbitMQ是如何保证高可用的?

RabbitMQ可以通过多种方式来实现高可用&#xff0c;以确保在硬件故障或其他不可预测的情况下&#xff0c;消息队列系统仍然能够正常运行。RabbitMQ有三种模式&#xff1a;单机模式、普通集群模式、镜像集群模式。 其中单机模式一般用于demo搭建&#xff0c;不适合在生产环境中…

搜索测试题题解(3月19号总结)

目录 1.Dungeon Master 2.Oil Deposits 3.Find a way 1.Dungeon Master Sample InputcopyOutputcopy 3 4 5 S.... .###. .##.. ###.###### ##### ##.## ##...##### ##### #.### ####E1 3 3 S## #E# ###0 0 0Escaped in 11 minute(s). Trapped! 这道题与普通的bfs模板题就是…

构建强大的API:Django中的REST框架探究与实践【第146篇—Django】

&#x1f47d;发现宝藏 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。【点击进入巨牛的人工智能学习网站】。 构建强大的API&#xff1a;Django中的REST框架探究与实践 在当今的Web开发中&#xff0c;构…

微服务cloud--抱团取暖吗 netflix很多停更了

抱团只会卷&#xff0c;卷卷也挺好的 DDD 高内聚 低耦合 服务间不要有业务交叉 通过接口调用 分解技术实现的复杂性&#xff0c;围绕业务概念构建领域模型&#xff1b;边界划分 业务中台&#xff1a; 数据中台&#xff1a; 技术中台&#xff1a; 核心组件 eureka&#x…

【C语言】动态内存管理及其常见错误

文章目录 1、前言&#xff1a;为什么要有动态内存分布2、三种动态内存的创建方式及其释放2.1 malloc2.2 calloc2.3 ralloc2.4 free 3、常⻅的动态内存的错误3.1 对NULL指针的解引用操作3.2 对动态开辟空间的越界访问3.3 对非动态开辟内存使用free释放3.4 使⽤free释放⼀块动态开…

Linux网络协议栈从应用层到内核层②

文章目录 1、bind 源码剖析2、listen 源码剖析3、accept 源码剖析4、connect 源码剖析客户端调用connect成功&#xff0c;但三次握手并未完成&#xff0c;进程是如何阻塞自己客户端在connect时&#xff0c;如何选择源端口客户发送syn封包以及重传服务端收到syn封包&#xff0c;…