标签:
javascript DOM常用API总结 作者:狼狼的蓝胖子 网址:http://www.cnblogs.com/lrzw32/p/5008913.html 文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认识。 基本概念 在讲解操作DOM的api之前,首先我们来复习一下一些基本概念,这些概念是掌握api的关键,必须理解它们。 Node类型 DOM1级定义了一个Node接口,该接口由DOM中所有节点类型实现。这个Node接口在JS中是作为Node类型实现的。在IE9以下版本无法访问到这个类型,JS中所有节点都继承自Node类型,都共享着相同的基本属性和方法。 Node有一个属性nodeType表示Node的类型,它是一个整数,其数值分别表示相应的Node类型,具体如下: Node.ELEMENT_NODE:1 Node.ATTRIBUTE_NODE:2 Node.TEXT_NODE:3 Node.CDATA_SECTION_NODE:4 Node.ENTITY_REFERENCE_NODE:5 Node.ENTITY_NODE:6 Node.PROCESSING_INSTRUCTION_NODE:7 Node.COMMENT_NODE:8 Node.DOCUMENT_NODE:9 Node.DOCUMENT_TYPE_NODE:10 Node.DOCUMENT_FRAGMENT_NODE:11 Node.NOTATION_NODE:12 假设我们要判断一个Node是不是元素,我们可以这样判断 if(someNode.nodeType == 1){ console.log("Node is a element"); } 这些Node类型中,我们最常用的就是element,text,attribute,comment,document,document_fragment这几种类型。 我们简单来介绍一下这几种类型: Element类型 Element提供了对元素标签名,子节点和特性的访问,我们常用HTML元素比如div,span,a等标签就是element中的一种。Element有下面几条特性: (1)nodeType为1 (2)nodeName为元素标签名,tagName也是返回标签名 (3)nodeValue为null (4)parentNode可能是Document或Element (5)子节点可能是Element,Text,Comment,Processing_Instruction,CDATASection或EntityReference Text类型 Text表示文本节点,它包含的是纯文本内容,不能包含html代码,但可以包含转义后的html代码。Text有下面的特性: (1)nodeType为3 (2)nodeName为#text (3)nodeValue为文本内容 (4)parentNode是一个Element (5)没有子节点 Attr类型 Attr类型表示元素的特性,相当于元素的attributes属性中的节点,它有下面的特性: (1)nodeType值为2 (2)nodeName是特性的名称 (3)nodeValue是特性的值 (4)parentNode为null Comment类型 Comment表示HTML文档中的注释,它有下面的几种特征: (1)nodeType为8 (2)nodeName为#comment (3)nodeValue为注释的内容 (4)parentNode可能是Document或Element (5)没有子节点 Document Document表示文档,在浏览器中,document对象是HTMLDocument的一个实例,表示整个页面,它同时也是window对象的一个属性。Document有下面的特性: (1)nodeType为9 (2)nodeName为#document (3)nodeValue为null (4)parentNode为null (5)子节点可能是一个DocumentType或Element DocumentFragment类型 DocumentFragment是所有节点中唯一一个没有对应标记的类型,它表示一种轻量级的文档,可能当作一个临时的仓库用来保存可能会添加到文档中的节点。DocumentFragment有下面的特性: (1)nodeType为11 (2)nodeName为#document-fragment (3)nodeValue为null (4)parentNode为null 我们简单地介绍了几种常见的Node类型,要记住,HTML中的节点并不只是包括元素节点,它还包括文本节点,注释节点等等。在这里我们只是简单地说明了几种常见的节点,想要进一步学习的同学可以查找一下相关资料。 节点创建型api 在这里,我将常用的DOM操作api进行分类,首先要介绍的是创建型的api。这一类型的api,简而言之就是用来创建节点的。 createElement createElement通过传入指定的一个标签名来创建一个元素,如果传入的标签名是一个未知的,则会创建一个自定义的标签,注意:IE8以下浏览器不支持自定义标签。 使用如下: var div = document.createElement("div"); 使用createElement要注意:通过createElement创建的元素并不属于html文档,它只是创建出来,并未添加到html文档中,要调用appendChild或insertBefore等方法将其添加到HTML文档树中。 createTextNode createTextNode用来创建一个文本节点,用法如下: var textNode = document.createTextNode("一个TextNode"); createTextNode接收一个参数,这个参数就是文本节点中的文本,和createElement一样,创建后的文本节点也只是独立的一个节点,同样需要appendChild将其添加到HTML文档树中 cloneNode cloneNode是用来返回调用方法的节点的一个副本,它接收一个bool参数,用来表示是否复制子元素,使用如下: var parent = document.getElementById("parentElement"); var parent2 = parent.cloneNode(true);// 传入true parent2.id = "parent2"; 这段代码通过cloneNode复制了一份parent元素,其中cloneNode的参数为true,表示parent的子节点也被复制,如果传入false,则表示只复制了parent节点。标签:
原文地址:http://www.cnblogs.com/aytsoft/p/5050426.html