问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

DOM Tutorial

创作时间:
作者:
@小白创作中心

DOM Tutorial

引用
CSDN
1.
https://blog.csdn.net/sunyctf/article/details/132558497

目录
一、DOM是什么
二、DOM的访问
三、DOM节点类型
四、DOM的分级

今天我们将了解WEB编程中一个重要的概念DOM(Document Object Model)文档对象模型,它帮助我们使用JavaScript(或其他编程语言)操纵文档。

一、DOM是什么

很多人会问 DOM 具体是什么东西呢?其实,DOM是HTML和XML文档的编程接口。它不同于把html源码在浏览器窗口当做页面或使用文本编辑器当做纯文本展示,它是对文档的另一种结构化的表述。DOM把文档的所有节点都解析为一个对象,并提供了一些属性和方法来描述它们。
根据W3C DOM规范,DOM是HTML与XML的应用编程接口(API),DOM将整个页面映射为一个由层次节点组成的文件。DOM 是文档对象模型(document object model)的缩写,它是一种提供对文档访问或修改方法的模型,它的范围很广,但对于 web 开发者来说,往往都认为它是指JavaScript在浏览器访问和修改html 文档的一种技术,但实际上范围远不局限在这里。
DOM是W3C的标准。它被分为3个部分:

  • 核心DOM:针对任何结构化文档的标准模型
  • XML DOM:针对XML文档的标准模型
  • HTML DOM:针对HTML文档的标准模型
    核心DOM:是用于XML与HTML的共用接口;XMLDOM:XML专用接口;HTML DOM:HTML专用接口;
    DOM不是一种编程语言,它是一种标准,一个模型,它与编程语言相对独立。编程语言都可以按照这种模型实现对文档的访问和处理。
    注:因为我们主要是学习WEB编程,所以接下来文章中即将提到的DOM均指HTML DOM,使用到的DOM API也均是JavaScript脚本语言实现。

二、DOM的访问

我们知道,各个浏览器对JavaScript都有不同的实现,所以它们在实现DOM标准时,也会有一些差异,但它们既然都遵循了该标准,所以又呈现出了不同程度一致性。我们在使用DOM时,并不需要做任何特别的操作,如果碰到有差异的地方(主要体现在方法名称和参数上),只需根据不同浏览器使用他们各自实现的相关方法即可。实际上他们的实现都遵循了统一标准。
DOM把文档视做树结构:

  • 整个文档是一个文档节点。
  • 每个 HTML 标签是一个元素节点。
  • 包含在 HTML 元素中的文本是文本节点。
  • 每一个 HTML 属性是一个属性节点。
  • 注释属于注释节点。
    HTML 文档中的所有节点组成了一个文档树(或节点树)。HTML 文档中的每个元素、属性、文本等都代表着树中的一个节点。树起始于文档节点,并由此继续伸出枝条,直到处于这棵树最低级别的所有文本节点为止。
    通过这个节点树,JavaScript可以轻松的访问并操作这些节点。Javascript获取到的每个节点都被解析成对象,遭DOM中,document是顶级对象,DOM元素的属性和方法大都源于此。
    **◼️ **举个栗子:请看下面这个HTML文档:
  
<html>
  <head>
    <title>DOM Tutorial</title>
  </head>
  <body>
    <h1>DOM Lesson one</h1>
    <p>Hello world!</p>
  </body>
</html>  

上面所有的节点彼此间都存在关系。
除文档节点之外的每个节点都有父节点。举例,和 的父节点是 节点,文本节点 "Hello world!" 的父节点是

节点。
大部分元素节点都有子节点。比方说,节点有一个子节点:节点。<title>节点也有一个子节点:文本节点 "DOM Tutorial"。<br>当节点分享同一个父节点时,它们就是同辈(同级节点)。比方说,<h1>和 <p>是同辈,因为它们的父节点均是 <body>节点。<br>节点也可以拥有后代,后代指某个节点的所有子节点,或者这些子节点的子节点,以此类推。比方说,所有的文本节点都是 <html>节点的后代,而第一个文本节点是 <head>节点的后代。 </p> <h4><strong>三、DOM节点类型</strong></h4> <p>每个节点对象有都有一个nodeType,nodeName和nodeValue属性,通过这几个属性的值,我们可以获取该节点的相关信息:<br>nodeType返回节点类型 nodeName 返回 nodeValue 返回<br>1 Element 元素名 null<br>2 Attr 属性名称 属性值<br>3 Text #text 节点的内容<br>4 CDATASection #cdata-section 节点的内容<br>5 EntityReference 实体引用名称 null<br>6 Entity 实体名称 null<br>7 ProcessingInstruction target 节点的内容<br>8 Comment #comment 注释文本<br>9 Document #document null<br>10 DocumentType 文档类型名称 null<br>11 DocumentFragment #document 片段 null<br>12 Notation 符号名称 null </p> <h4><strong>四、DOM的分级</strong></h4> <p>DOM 分级仅做了解即可。DOM的级别分类如下:<br><strong>一级DOM(DOM Level 1)</strong><br>1级DOM在1998年10月份成为W3C的推荐标准,由DOM核心(DOM Core)与DOM HTML两个模块组成。DOM核心能映射以XML为基础的文档结构,允许获取和操作文档的任意部分。DOM HTML通过添加HTML专用的对象与函数对DOM核心进行了扩展。<strong>简单来说,DOM1级就是映射文档结构和提供基本的文档操作方法。</strong><br><strong>二级DOM(DOM Level 2)</strong><br>2级DOM在一级DOM的基础上进行了扩展,它引进了几个新DOM模块来处理新的接口类型: </p> <ul> <li>DOM视图:描述跟踪一个文档的各种视图(使用CSS样式设计文档前后)的接口; </li> <li>DOM事件:描述事件接口; </li> <li>DOM样式:描述处理基于CSS样式的接口; </li> <li>DOM遍历与范围:描述遍历和操作文档树的接口;根据DOM,HTML文档中的每个成分都是一个节点<br>DOM2级,就是对DOM1级进行扩展,2级DOM通过对象接口增加对鼠标和用户界面事件(DHTML长期支持鼠标与用户界面事件)、范围、遍历(重复执行DOM文档)和层叠样式表(CSS)的支持。同时也对DOM1进行了扩展,从而可支持XML命名空间。<strong>简单来说,DOM2级就是在DOM1的基础上增加了视图、事件、样式、遍历和范围的接口,和支持XML命名空间。</strong><br><strong>三级DOM(DOM Level 3)</strong><br>3级DOM通过引入统一方式载入和保存文档和文档验证方法对DOM进行进一步扩展,DOM3包含一个名为“DOM载入与保存”的新模块,DOM核心扩展后可支持XML1.0的所有内容,包括XML Infoset、 XPath、和XML Base。 <br>DOM3级,在前面DOM基础上,引入了以统一方式加载和保存文档的方法,新增了验证文档的方法,同时也对DOM核心进行了扩展,开始支持XML1.0规范。 <br><strong>零级DOM(DOM Level 0)</strong><br>0级DOM其实并不真实存在,业内通常把W3C标准化之前的DOM相关称为0级DOM。<br>其实,除了上面的三个等级之外,还有一个叫DOM0级的东西,实际上标准并没有这个东西,它指的是IE4和Netscape Navigator 4.0 最初支持的DHTML,DHTML实际上是HTML、CSS和JS的一个集成,代表的是一种已有的技术,不是标椎,所以DOM0级其实代表的是历史节点中未形成标准的一个初期产物。<br>举一个常见的DOM0级事件和DOM2级事件的比较:绑定按钮的onclick赋值为一个函数就是DOM0级的,但是onclick多次赋值不同函数,最后也会被后面的函数覆盖掉;而DOM2级利用提供的addEventListener方法监听按钮的click事件,多次写监听同一个事件,函数会被依次执行的,不会被覆盖。<br><strong>◼️ 参考资料</strong><br>快速了解JavaScript的DOM模型 - 知乎 | DOM 的级别分类 - 简书<br>DOM所包含的主要内容有哪几部分| DOM的分级_随笔_内存溢出<br>JavaScript WebAPI笔记DOM篇 - CSDN博客</li> </ul> <div id="show" style="display: block;width: 0;height: 0;visibility: hidden;opacity: 0;"></div><script src="https://www.wenxiaobai.com/common-bridge-sdk.js"></script><script src="https://www.wenxiaobai.com/baike-huaxian.js"></script><script> const firstSection = document.querySelector('section'); firstSection?.setAttribute('open', ''); document.querySelectorAll('section header').forEach(header => { header.addEventListener('click', function() { const section = this.parentElement; if (section.hasAttribute('open')) { section.removeAttribute('open'); } else { section.setAttribute('open', ''); } }); }); </script><script> document.querySelectorAll('.refer-header').forEach(header => { header.addEventListener('click', function() { const section = this.parentElement; if (section.hasAttribute('open')) { section.removeAttribute('open'); } else { section.setAttribute('open', ''); } }); }); </script></body></html>

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号