BOM有一些事实上的标准,如窗口对象、导航对象等,但每种浏览器都为这些对象定义或扩展了属性及方法。Document Object Model,这个就是标准了,由著名的w3c制定,目前最高的级别是level 3,不过3尚未完全完成。css
目前主流的浏览器均可以支持到(仅仅是支持到哦,并非彻底遵照的)level 2,对html,也就是html4.x,目前最高的是4.01,后来w3c向把html统一贯xml靠拢,因而就有了xhtml1.0,再后来,w3c想搞一个xhtml2.0,结果进度缓慢,加之各大厂商又不看好,因而就有了html5.0html
一、建立节点html5
- createElement():
- var a = document.createElement(“p”);
它建立的是一个元素节点,因此nodeType等于1,a.nodeName将返回p。node
注意;createElement()方法建立出来的新元素节点不会被自动添加到文档里,既然没添加到文档里,说明它仍是一个游离的状态。因此它也没有nodeParent属性。若是想把它添加到文档里,可使用 appendChild()或者insertBefore()方法或者replaceChild()方法。固然咱们在前面的例子中,本身写了一个 insertAfter()方法,好比:数组
- var a = document.createElement(“p”);
- document.body.appendChild(a);
注意: appendChild()默认是添加到文档的最后。也就是lastChild子节点。若是想添加到某个地方,可使用insertBefore()。若是想在元素插入以前给元素添加属性。能够这么作:浏览器
- var a = document.createElement(“p”);
- a.setAttribute(“title”,”my demo”);
- document.body.appendChild(a);
- createTextNode():
- var b = document.createTextNode(“my demo”);
它建立的是一个文本节点,因此nodeType等于3 。b.nodeName 将返回 #text ; 跟createElement()同样,用createTextNode()建立的节点也不会自动添加到文档里。须要使用 appendChild()或者insertBefore()方法或者replaceChild()方法。它常常与createElement()配合使用,知道为何吗?(一个元素节点,一个文本节点。)app
- var mes = document.createTextNode(“hello world”);
- var container = document.createElement(“p”);
- container.appendChild(mes);
- document.body.appendChild(container);
二、复制节点spa
cloneNode(boolean):ssr
- var mes = document.createTextNode("hello world");
- var container = document.createElement("p");
- container.appendChild(mes);
- document.body.appendChild(container);
- var newpara = container.cloneNode(true);//true和false的区别
- document.body.appendChild(newpara );
注意:
◆true的话:是<p>aaaa</p>克隆。
◆false: 只克隆 <p></p>,里面的文本不克隆。
◆能够本身写个例子,而后用firebug看看。xml
克隆后的新节点,和createTextNode()同样 不会被自动插入到文档 。须要appendChild();另外还有一个注意: 若是克隆后,id同样,不要忘记用 setAttribute(“id” , “ another_id “);改变新的节点的ID。
三、插入节点
appendChild() :
- var container = document.createElement("p");
- var t = document.createTextNode("cssrain");
- container.appendChild(t);
- document.body.appendChild(container);
它常常跟createElement()和createTextNode(),cloneNode()配合使用。另外appendChild()不只能够用来追加新的元素,也能够你挪动文档中现有的元素。看下面的例子:
- <p id="msg">msg</p>
- <p id="content">content</p>
- <p id="aaa">aaaaaaaa</p>
- <script>
- var mes = document.getElementById("msg");
- var container = document.getElementById("content");
- container.appendChild(mes);
- </script>
- //发现msg放到 content 后面去了。
- <p id="content">
- content
- <p id="msg">msg</p>
- </p>
- <p id="aaa">aaaaaaaa</p>
第二个参数是可选,若是第二个参数不写,将默认添加到文档的最后,至关于appendChild();咱们看看insertBefore()怎么使用:
- <div id="cssrian">
- <p id="content">1111</p>
- <div id="msg">msg<div>test</div></div>
- <p id="content">222</p>
- <p id="aaa">aaaaaaaa</p>
- </div>
- <script>
- var msg = document.getElementById("msg");
- var aaa = document.getElementById("aaa");
- var test = document.getElementById("cssrian");
- test.insertBefore( msg , aaa );
- </script>
- // 咱们发现ID为msg的 插入到了aaa的前面。
Js内部处理方式跟 appendChild()类似。
四、删除节点
removeChild():
- <body>
- <div id="cssrain">
- <div id="a">a </div>
- <div id="b">b </div>
- <div id="c">c </div>
- </div>
- </body>
- <script>
- var msg = document.getElementById("cssrain");
- var b = document.getElementById("b");
- msg.removeChild(b);
- </script>
若是不知道要删除的节点的父节点是什么?可使用parentNode属性。好比:
- <body>
- <div id="cssrain">
- <div id="a">a </div>
- <div id="b">b </div>
- <div id="c">c </div>
- </div>
- </body>
- <script>
- var b = document.getElementById("b");
- var c = b.parentNode;
- c.removeChild(b);
- </script>
注意:你若是想把某个节点从一处移动到另外一个地方,没必要使用removeChild()。可使用前面的 appendChild()和insertBefore(),他们都会自动先删除节点,而后移动到你指定的地方。、
五、替换节点
- Element.repalceChild( newNode , oldNode ):
-
- <body>
- <div id="cssrain">
- <div id="a">a </div>
- <div id="b">b </div>
- <div id="c">c </div>
- </div>
- </body>
- <script>
- var cssrain = document.getElementById("cssrain");
- var msg = document.getElementById("b");
- var para = document.createElement("p");
- cssrain.replaceChild( para , msg );
- </script>
六、设置/获取属性节点
- setAttribute();//设置
-
- var a = document.createElement(“p”);
- a.setAttribute(“title”,”my demo”);
-
- var a =document.getElementById(“cssrain”);
- var b = a.getAttribute(“title”);
获取的时候,若是属性不存在,则返回空,注意ie和ff返回不一样,能够看我之前的例子。 返回虽然不一样,可是能够用一个方法来判断:if(a.getAttribute(“title”) ){ }
七、查找节点
getElementById();
返回一个对象,对象拥有 nodeName , nodeType , parentNode , ChildNodes 等属性。getElementsByTagName():查找标签名的全部元素。返回一个集合,能够用循环取出每一个对象,对象拥有 nodeName , nodeType , parentNode , ChildNodes 等属性。 例子:
- var ps = document.getElementsByTagName(“p”);
- for(var i=0 ; i< ps.length ; i++){
- ps[i].setAttribute(“title”,”hello”);
- //也可使用: ps.item(i).setAttribute("title","hello");
- }
-
- <body>
- <div id="cssrain">
- <div id="a">a </div>
- <div id="b">b </div>
- <div id="c">c </div>
- </div>
- </body>
- <script>
- var ps = document.getElementById("cssrain")
- if(ps.hasChildNodes){
- alert( ps.childNodes.length );
- }
- </script>
八、DOM属性
咱们经常使用的3中类型:
nodeType == 1 : 元素节点
nodeType == 2 : 属性节点
nodeType == 3 : 文本节点
若是想记住的话,上面的顺序咱们能够看作是从前到后。好比:<p title="cssrain" >test</p> 从前日后读:你会发现先是元素节点,而后是属性节点,最后是文本节点,这样你就很容易记住了nodeType分别表明什么类型了。nodeType属性常常跟if配合使用,以确保不会在错误的节点类型上执行错误的操做。好比:
- function cs_demo(mynode){
- if(mynode.nodeType == 1){
- mynode.setAttribute("title","demo");
- }
- }
代码解释:先检查mynode的nodeType属性,以确保它所表明的节点确实是一个元素节点。和nodeName属性同样,他也是只读属性,不能进行设置.
- <div id="c">aaaaaaaaaaaaaaaa</div>
- <SCRIPT LANGUAGE="JavaScript">
- var c= document.getElementById("c");
- alert( c.nodeValue );//返回null
- </SCRIPT>
nodeValue是一个能够读、写的属性。 但它不能设置元素节点的值。看下面的例子:
- <div id="c">aaaaaaaaaaaaaaaa</div>
- <SCRIPT LANGUAGE="JavaScript">
- var c= document.getElementById("c");
- c.nodeValue =" dddddddddddd"; //不能设置
- //alert( c.firstChild.nodeValue ) //元素节点 包括属性节点和文本节点。
- c.firstChild.nodeValue = "test"//能设置
- </SCRIPT>
固然咱们为了确保能正确运行:能够加一段代码:
- <div id="c">aaaaaaaaaaaaaaaa</div>
- <SCRIPT LANGUAGE="JavaScript">
- var c= document.getElementById("c");
- c.nodeValue =" dddddddddddd"; //不能设置
- //alert( c.firstChild.nodeValue )
- if( c.firstChild.nodeType==3 ){ //判断是否是 文本节点
- c.firstChild.nodeValue = "test"//能设置
- }
- </SCRIPT>
nodeValue通常只用来设置 文本节点的值。若是要刷新属性节点的值,通常使用setAttribute(). childNodes属性:返回一个数组,数组由元素节点的子节点构成。因为文本节点和属性节点都不可能再包含任何子节点,因此他们的childNodes属性永远返回一个空数组。
可使用hasChildNodes方法,它用来判断某个元素有没有子节点。或者if (container.childNodes.length < 1) ;childNodes也是一个只读属性。若是要增长节点,可使用appendChild()或者insertBefore() ,删除节点可使用removeChild(); 操做后,childNodes属性会自动刷新。
firstChild属性
因为文本节点和属性节点都不可能再包含任何子节点,因此他们的firstChild属性永远返回一个空数组。 若是没有子节点,将返回null;node.firstChild 等价于 node.childNodes[0] ; firstChild属性是一个只读属性。
lastChild属性
因为文本节点和属性节点都不可能再包含任何子节点,因此他们的lastChild属性永远返回一个空数组。 若是没有子节点,将返回null; node.lastChild 等价于 node.childNodes[ node.childNodes.length - 1 ] ;lastChild属性是一个只读属性。
nextSibling属性
返回目标节点的下一个兄弟节点。若是目标节点后面没有同属于一个父节点的节点,nextSibling 将返回null ;nextSibling 属性是一个只读属性。
previousSibling属性
返回目标节点的前一个兄弟节点。若是目标节点前面没有同属于一个父节点的节点,previousSibling 将返回null ;previousSibling 属性是一个只读属性。
parentNode属性
注:parentNode属性返回的节点永远是一个元素节点,由于只有元素节点才有可能有子节点。