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博客

  • 30
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学习&实践爱好者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值