关于DOM

前言

DOM的作用是将网页转为一个javascript对象,从而可以使用javascript对网页进行各种操作(比如增删内容)。浏览器会根据DOM模型,将HTML文档解析成一系列的节点,再由这些节点组成一个树状结构。DOM的最小组成单位叫做节点(node),文档的树形结构(DOM树)由12种类型的节点组成。

一:DOM ==> 全称: document Object Mode   文档对象模型

文档: html页面

文档对象:页面元素(节点)

文档对象模型: W3C标准定义:为了能够使用javascript去操作页面中的元素定义出来的标准

二:DOM会把文档当成一节点树,文档里面的每一个元素都是一个节点。同时定义了很多方法来操作这些节点(元素)

三:属性

  什么是属性:

    1.使用的时候不用再前面加括号

    2.一个属性肯定是某个对象下面的,所以在使用的时候肯定是调用某个对象(元素)下面的属性

  元素.childNodes     (存在兼容性,不推荐使用,推荐使用另一个 children)

      元素.children  (不管在标准还是非标准下,只包含元素类型的节点。推荐使用)

    特点:只读属性。

    代表:子节点列表集合,试剂盒就有长度,可使用数组形式获取

    只包含儿子子节点,不包含孙子子节点

    获取:实行 [] 下表获取

    标准模式下(非IE):childNodes 包含了文本和元素类型节点,也会包含非法嵌套的子节点(注意:不是孙子节点)

    非标准:childNodes只包含元素类型的节点。ie7以不会包含非法嵌套子节点

    ul元素下面的所有子元素都包括在这个childNodes属性里面

    访问ul里面的所有 li 子元素形式:

      var oul =  document.getElementById(‘ul‘);

      oul.childNodes.length    // 9  标准模式下

1 <ul id=‘ul‘>
2     <li>1</li>
3     <li>2</li>
4     <li>3</li>
5     <li>4</li>
6 </ul>

为什么是9呢?

DOM里面定义了12种节点:

一般地,节点至少拥有nodeTypenodeNamenodeValue这三个基本属性。

元素.nodeType     1 

  只读属性,代表当前元素的类型

  nodeType属性返回节点类型的常数值。不同的类型对应不同的常数值,12种类型分别对应1到12的常数值

元素.attributes

  只读属性,代表当前元素的属性是什么(如:id,border,,,等属性)

  属性列表集合

  属性的名称:元素.attributes[0].name

  属性的值:元素.attributes[0].value

 1 <ul id=‘ul‘ style= ‘color‘,‘red‘>
 2     <li>1</li>
 3     <li>2</li>
 4     <li>3</li>
 5     <li>4</li>
 6 </ul>
 7
 8 var oul =  document.getElementById(‘ul‘);
 9 oul.attributes.length  //2
10 oul.attributes[0].name  //id
11 元素.attributes[1].value  //red

--------------------------------------------------------------------------------------------------------------------

--------------------------------------------------------------------------------------------------------------------

元素节点                   Node.ELEMENT_NODE(1)   nodeType值: 1

属性节点                   Node.ATTRIBUTE_NODE(2)  nodeType值: 2

文本节点                   Node.TEXT_NODE(3)  nodeType值: 3

CDATA节点                    Node.CDATA_SECTION_NODE(4)   nodeType值: 4

实体引用名称节点        Node.ENTRY_REFERENCE_NODE(5)  nodeType值: 5

实体名称节点             Node.ENTITY_NODE(6)  nodeType值: 6

处理指令节点             Node.PROCESSING_INSTRUCTION_NODE(7)   nodeType值: 7

注释节点                      Node.COMMENT_NODE(8)   nodeType值: 8

文档节点                      Node.DOCUMENT_NODE(9)   nodeType值: 9

文档类型节点            Node.DOCUMENT_TYPE_NODE(10)   nodeType值: 10

文档片段节点            Node.DOCUMENT_FRAGMENT_NODE(11)   nodeType值: 11

DTD声明节点                 Node.NOTATION_NODE(12)   nodeType值: 12

--------------------------------------------------------------------------------------------------------------------

--------------------------------------------------------------------------------------------------------------------

DOM定义了一个Node接口,这个接口在javascript中是作为Node类型实现的,而在IE8-浏览器中的所有DOM对象都是以COM对象的形式实现的。所以,IE8-浏览器并不支持Node对象的写法

1 //在标准浏览器下返回1,而在IE8-浏览器中报错,提示Node未定义  2 console.log(Node.ELEMENT_NODE);//1

nodeName

nodeName属性返回节点的名称

nodeValue

nodeValue属性返回或设置当前节点的值,格式为字符串

接下来,将按照节点类型的常数值对应顺序,从1到12进行详细说明

【1】元素节点

元素节点element对应网页的HTML标签元素。元素节点的节点类型nodeType值是1,节点名称nodeName值是大写的标签名,nodeValue值是null

以body元素为例

1 // 1 ‘BODY‘ null
2 console.log(document.body.nodeType,document.body.nodeName,document.body.nodeValue)
3 console.log(Node.ELEMENT_NODE === 1);//true

【2】特性节点

元素特性节点attribute对应网页中HTML标签的属性,它只存在于元素的attributes属性中,并不是DOM文档树的一部分。特性节点的节点类型nodeType值是2,节点名称nodeName值是属性名,nodeValue值是属性值

现在,div元素有id="test"的属性

1 <div id="test"></div>
2 <script>
3     var attr = test.attributes.id;
4     //2 ‘id‘ ‘test‘
5     console.log(attr.nodeType,attr.nodeName,attr.nodeValue)
6     console.log(Node.ATTRIBUTE_NODE === 2);//true
7 </script>

【3】文本节点

文本节点text代表网页中的HTML标签内容。文本节点的节点类型nodeType值是3,节点名称nodeName值是‘#text‘,nodeValue值是标签内容值

现在,div元素内容为‘测试‘

1 <div id="test">测试</div>
2 <script>
3     var txt = test.firstChild;
4     //3 ‘#text‘ ‘测试‘
5     console.log(txt.nodeType,txt.nodeName,txt.nodeValue)
6     console.log(Node.TEXT_NODE === 3);//true
7 </script>

【4】CDATA节点

CDATASection类型只针对基于XML的文档,只出现在XML文档中,表示的是CDATA区域,格式一般为

1 <![CDATA[
2 ]]>

该类型节点的节点类型nodeType的值为4,节点名称nodeName的值为‘#cdata-section‘,nodevalue的值是CDATA区域中的内容

【5】实体引用名称节点

实体是一个声明,指定了在XML中取代内容或标记而使用的名称。 实体包含两个部分, 首先,必须使用实体声明将名称绑定到替换内容。 实体声明是使用 <!ENTITY name "value"> 语法在文档类型定义(DTD)或XML架构中创建的。其次,在实体声明中定义的名称随后将在 XML 中使用。 在XML中使用时,该名称称为实体引用。

实体引用名称节点entry_reference的节点类型nodeType的值为5,节点名称nodeName的值为实体引用的名称,nodeValue的值为null

1 //实体名称
2 <!ENTITY publisher "Microsoft Press">
3 //实体名称引用
4 <pubinfo>Published by &publisher;</pubinfo>

【6】实体名称节点
上面已经详细解释过,就不再赘述

该节点的节点类型nodeType的值为6,节点名称nodeName的值为实体名称,nodeValue的值为null

【7】处理指令节点

处理指令节点ProcessingInstruction的节点类型nodeType的值为7,节点名称nodeName的值为target,nodeValue的值为entire content excluding the target

【8】注释节点

注释节点comment表示网页中的HTML注释。注释节点的节点类型nodeType的值为8,节点名称nodeName的值为‘#comment‘,nodeValue的值为注释的内容

现在,在id为myDiv的div元素中存在一个<!-- 我是注释内容 -->

1 <div id="myDiv"><!-- 我是注释内容 --></div>
2 <script>
3     var com = myDiv.firstChild;
4     //8 ‘#comment‘ ‘我是注释内容‘
5     console.log(com.nodeType,com.nodeName,com.nodeValue)
6     console.log(Node.COMMENT_NODE === 8);//true
7 </script>

【9】文档节点

文档节点document表示HTML文档,也称为根节点,指向document对象。文档节点的节点类型nodeType的值为9,节点名称nodeName的值为‘#document‘,nodeValue的值为null

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Document</title>
 6 </head>
 7 <body>
 8 <script>
 9     var nodeDocumentType = document.firstChild;
10     //10 "html" null
11     console.log(nodeDocumentType.nodeType,nodeDocumentType.nodeName,nodeDocumentType.nodeValue);
12     console.log(Node.DOCUMENT_TYPE_NODE === 10);
13 </script>
14 </body>15 </html>

【11】文档片段节点

文档片段节点DocumentFragment在文档中没有对应的标记,是一种轻量级的文档,可以包含和控制节点,但不会像完整的文档寻亲战胜额外的资源。该节点的节点类型nodeType的值为11,节点名称nodeName的值为‘#document-fragment‘,nodeValue的值为null

1 <script>
2     var nodeDocumentFragment = document.createDocumentFragment();
3     //11 "#document-fragment" null
4     console.log(nodeDocumentFragment.nodeType,nodeDocumentFragment.nodeName,nodeDocumentFragment.nodeValue);
5     console.log(Node.DOCUMENT_FRAGMENT_NODE === 11);//true
6 </script>

【12】DTD声明节点

DTD声明节点notation代表DTD中声明的符号。该节点的节点类型nodeType的值为12,节点名称nodeName的值为符号名称,nodeValue的值为null

总结

在这12种DOM节点类型中,有一些适用于XML文档,有一些是不常用的类型。而对于常用类型,后面会陆续进行详细介绍,本文对这12种节点类型只做概述,希望本文对大家能有所帮助。

-转载

时间: 2024-10-12 17:28:30

关于DOM的相关文章

虚拟DOM

DOM(Document Object Model)是很慢的,其元素非常庞大,页面的性能问题鲜有由JS引起的,大部分都是由DOM操作引起的.如果对前端工作进行抽象的话,主要就是维护状态和更新视图:而更新视图和维护状态都需要DOM操作. 在jQuery出现以前,我们直接操作DOM结构,这种方法复杂度高,兼容性也较差:有了jQuery强大的选择器以及高度封装的API,我们可以更方便的操作DOM,jQuery帮我们处理兼容性问题,同时也使DOM操作变得简单:MVVM使用数据双向绑定,使得我们完全不需要

JS学习--DOM

1.概念 文档对象模型DOM,定义访问和处理HTML文档的标准方法.DOM将HTML呈现为带有元素.属性和文本的树结构(节点树). 2.document.getElementById("id")--获取的是一个元素对象. documment.getElementById("id").innerHTML--才可获取其中的内容. 3.HTML样式 Object.style.property=new style;部分属性: 如: mychar.style.color=&q

高性能WEB开发:DOM编程

我们知道,DOM是用于操作XML和HTML文档的应用程序接口,用脚本进行DOM操作的代价很昂贵.有个贴切的比喻,把DOM和Javascript(这里指ECMscript)各自想象为一个岛屿,它们之间用收费桥梁连接,ECMAscript每次访问DOM,都要途径这座桥,并交纳"过桥费",访问DOM的次数越多,费用也就越高.因此,推荐的做法是尽量减少过桥的次数,努力待在ECMAscript岛上.我们不可能不用DOM的接口,那么,怎样才能提高程序的效率? 1.DOM访问与修改 访问DOM元素是

dom方法insertAfter的实现

在dom的原生api中,只用insertBefore,没有insertAfter,借助原有的api,可以模拟一个insterAfter. function insterAfter(newElement,targetElement){ var parent = targetElement.parentNode; if(parent.lastChild == targetElement){ parent.appendChild(newElement); } else{ parent.insertBe

第十章—DOM(0)—NODE类型

DOM1定义了一个node接口,该接口由DOM的所有节点类型实现. 所有的节点都存在这样或那样的关系.在HTML中,head,body可以看出是html的子元素,html是head,body的父元素,而head,body互为同胞元素. 这里要注意一个概念:nodeList 输出: 如下例子: 1 <div id="myDiv"> </div><!-- 此处有空格 --> 2 <script> 3 var div = document.ge

对dom的初步了解

什么叫DOM,DOM是文档对象模型Document Object Model DOM树 : 根结点(document) 父结点(parentNode) 子结点(childNodes) 兄弟结点 兄弟结点 sibling) (sibling) DOM在HTML文档中常见的几种结点类型:1.DOCUMENT_NODE (document)文档根结点类型,该枚举型的值是9. 2.ELEMENT_NODE (element)元素结点类型,该枚举型的值是1.上文中的html, body, div这些结点都

DOM基础(一)

在我们刚刚学JavaScript的时候,就应该听说过,JavaScript是由三部分组成的.分别是ECMAScript,DOM和BOM组成的.ECMAScript是JavaScript的核心,它描述了JavaScript的基本语法和对象,DOM则是描述了处理网页内容的方法和接口,而BOM描述了与浏览器进行交互的方法和接口.在我之前的关于JS入门系列的文章里,就讲了许多关于JavaScript的基本语法和对象,也就是ECMAScript.而在这个DOM系列的文章里,我将会介绍一些关于DOM的基础.

python2.0_s12_day13_javascript&amp;Dom&amp;jQuery

今天主要内容:JavaScriptDomjQuery http://www.cnblogs.com/wupeiqi/articles/5369773.html 今天主要内容大致了解:javascript 1.首先要知道 JavaScript 和 Java 没有半毛钱关系. 2.JavaScript 和python语言 一样 它也是一门语言.对于python语言需要用python解释器解释.而javascript的解释器是浏览器. 3.javascript 能实现什么.javascript就是让我

BOM和DOM

BOM 浏览器对象模型 BOM中的对象 Window对象:是指窗口对象,可通过Window对象的属性和方法控制窗口,例如打开或关闭一个窗口 History对象:指历史页面,通过History对象的属性和方法实现前进后退的功能 Location对象:指地址栏,通过属性的方法控制页面的跳转 Document对象:指网页中的内容,通过属性和方法控制页面元素 1.Window对象的常用方法: open(); close(); alert(); prompt(); confim(); setTimeout

JavaScript实现绑定DOM的定时器插件

问题 使用原生的setTimeout和setInterval仅仅能够实现, 定时执行事件处理函数, 在网页开发中, 往往会出现一种情况,定时器用于定时更新某个页面区域的数据, 往往在页面加载之后, 就启动这个定时器, 往后则间隔执行此定时器. 页面上定时刷新的区域可能会动态消失, 特别是在ajax被广泛使用的今天, 如果定时刷新的区域被删除了, 则定时器材也需要自动清除掉. 此二个接口,如果实现这种效果需要, 自己维护定时器句柄, 并且在处理定时器事件函数的时候, 首先判断 指定的刷新区域是否还