前言

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种节点类型只做概述,希望本文对大家能有所帮助。

-转载

关于DOM的更多相关文章

  1. 关于DOM的操作以及性能优化问题-重绘重排

     写在前面: 大家都知道DOM的操作很昂贵. 然后贵在什么地方呢? 一.访问DOM元素 二.修改DOM引起的重绘重排 一.访问DOM 像书上的比喻:把DOM和JavaScript(这里指ECMScri ...

  2. 读书笔记:JavaScript DOM 编程艺术(第二版)

    读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...

  3. 页面嵌入dom与被嵌入iframe的攻防

    1.情景一:自己的页面被引入(嵌入)至别人的页面iframe中 if(window.self != window.top){ //url是自己页面的url window.top.location.hr ...

  4. 通俗易懂的来讲讲DOM

    DOM是所有前端开发每天打交道的东西,但是随着jQuery等库的出现,大大简化了DOM操作,导致大家慢慢的“遗忘”了它的本来面貌.不过,要想深入学习前端知识,对DOM的了解是不可或缺的,所以本文力图系 ...

  5. HTML DOM 介绍

    本篇主要介绍DOM内容.DOM 节点.节点属性以及获取HTML元素的方法. 目录 1. 介绍 DOM:介绍DOM,以及对DOM分类和功能的说明. 2. DOM 节点:介绍DOM节点分类和节点层次. 3 ...

  6. HTML DOM 对象

    本篇主要介绍HTML DOM 对象:Document.Element.Attr.Event等4个对象. 目录 1. Document 对象:表示文档树的根节点,大部分属性和方法都是对元素进行操作. 2 ...

  7. 重撸js_2_基础dom操作

    1.node 方法 返回 含义 nodeName String 获取节点名称 nodeType Number 获取节点类型 nodeValue String 节点的值(注意:文本也是节点) 2.inn ...

  8. 虚拟dom与diff算法 分析

    好文集合: 深入浅出React(四):虚拟DOM Diff算法解析 全面理解虚拟DOM,实现虚拟DOM

  9. 窥探Vue.js 2.0 - Virtual DOM到底是个什么鬼?

    引言 你可能听说在Vue.js 2.0已经发布,并且在其中新添加如了一些新功能.其中一个功能就是"Virtual DOM". Virtual DOM是什么 在之前,React和Em ...

  10. jQuery学习之路(2)-DOM操作

    ▓▓▓▓▓▓ 大致介绍 jQuery作为JavaScript库,继承并发扬了JavaScript对DOM对象操作的特性,使开发人员能方便的操作DOM对象. ▓▓▓▓▓▓ jQuery中的DOM操作 看 ...

随机推荐

  1. C#.NET如何不序列化字段、属性

    当我们使用公开属性以及公开字段时,都可以顺利的被序列化, 01.[Serializable] 02.public class MyClass 03.{ 04.    public int ID; 05 ...

  2. Android -- startActivityForResult-------&&&----setResult

    startActivityForResult与startActivity的不同之处 startActivity( ) 仅仅是跳转到目标页面,若是想跳回当前页面,则必须再使用一次startActivit ...

  3. UITableView和UICollectionView的方法学习一

    参考资料 UITableView UICollectionView UICollectionViewDataSource UICollectionViewDelegate UICollectionVi ...

  4. 直接放个DB2 SQL STATEMENT大全好了!

    SQL statements   This topic contains tables that list the SQL statements classified by type. SQL sch ...

  5. NYOJ题目96 n-1位数

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAscAAAJgCAIAAADpjVkvAAAgAElEQVR4nO3du04jS/gv7H0T5FwIsa ...

  6. bnuoj 24251 Counting Pair

    一道简单的规律题,画出二维表将数字分别相加可以发现很明显的对称性 题目链接:http://www.bnuoj.com/v3/problem_show.php?pid=24251 #include< ...

  7. max virtual memory areas vm.max_map_count [65530] likely too low, increase to at least [262144]

    sh- /etc/sysctl.conf vm.max_map_count = #在/etc/sysctl.conf追加上面一条 #并执行命令: sysctl -p

  8. @ifconfig eth0|awk -F "[ :]+" 'NR==2{print $4 "/" $NF}'中"[ :]+" 是什么意思?@

    http://blog.csdn.net/zhuying_linux/article/details/6822987

  9. python面向对象进阶 反射 单例模式 以及python实现类似java接口功能

    本篇将详细介绍Python 类的成员.成员修饰符.类的特殊成员. 类的成员 类的成员可以分为三大类:字段.方法和特性. 注:所有成员中,只有普通字段的内容保存对象中,即:根据此类创建了多少对象,在内存 ...

  10. eclipse基础及开发插件

    Eclipse:http://www.eclipse.org/downloads/ Compare Package:http://www.eclipse.org/downloads/packages/ ...