您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關JavaScript中BOM和DOM有什么區(qū)別,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
BOM定義了JavaScript可以進行操作的瀏覽器的各個功能部件的接口,提供訪問文檔各個功能部件(如窗口本身、屏幕功能部件、瀏覽歷史記錄等)的途徑以及操作方法。
遺憾的是,BOM只是JavaScript腳本實現(xiàn)的一部分,沒有任何相關的標準,每種瀏覽器都有自己的BOM實現(xiàn),這可以說是BOM的軟肋所在通常情況下瀏覽器特定的JavaScript擴展都被看作BOM的一部分,主要包括:
◆關閉、移動瀏覽器及調整瀏覽器窗口大?。?
◆彈出新的瀏覽器窗口;
◆提供瀏覽器詳細信息的定位對象;
◆提供載入到瀏覽器窗口的文檔詳細信息的定位對象;
◆提供用戶屏幕分辨率詳細信息的屏幕對象;
◆提供對cookie的支持;
◆加入ActiveXObject類擴展BOM,通過JavaScript實例化ActiveX對象。
BOM有一些事實上的標準,如窗口對象、導航對象等,但每種瀏覽器都為這些對象定義或擴展了屬性及方法。Document Object Model,這個就是標準了,由著名的w3c制定,目前***的級別是level 3,不過3還沒有徹底完成。
目前主流的瀏覽器都可以支持到(僅僅是支持到哦,并不是完全遵守的)level 2,對html,也就是html4.x,目前***的是4.01,后來w3c向把html統(tǒng)一向xml靠攏,于是就有了xhtml1.0,再后來,w3c想搞一個xhtml2.0,結果進度緩慢,加之各大廠商又不看好,于是就有了html5.0
1、創(chuàng)建節(jié)點
createElement(): var a = document.createElement(“p”);
它創(chuàng)建的是一個元素節(jié)點,所以nodeType等于1,a.nodeName將返回p。
注意;createElement()方法創(chuàng)建出來的新元素節(jié)點不會被自動添加到文檔里,既然沒添加到文檔里,說明它還是一個游離的狀態(tài)。所以它也沒有nodeParent屬性。如果想把它添加到文檔里,可以使用 appendChild()或者insertBefore()方法或者replaceChild()方法。當然我們在前面的例子中,自己寫了一個 insertAfter()方法,比如:
var a = document.createElement(“p”); document.body.appendChild(a);
注意: appendChild()默認是添加到文檔的***。也就是lastChild子節(jié)點。如果想添加到某個地方,可以使用insertBefore()。如果想在元素插入之前給元素添加屬性??梢赃@么做:
var a = document.createElement(“p”); a.setAttribute(“title”,”my demo”); document.body.appendChild(a); createTextNode(): var b = document.createTextNode(“my demo”);
它創(chuàng)建的是一個文本節(jié)點,所以nodeType等于3 。b.nodeName 將返回 #text ; 跟createElement()一樣,用createTextNode()創(chuàng)建的節(jié)點也不會自動添加到文檔里。需要使用 appendChild()或者insertBefore()方法或者replaceChild()方法。它經常與createElement()配合使用,知道為什么嗎?(一個元素節(jié)點,一個文本節(jié)點。)
var mes = document.createTextNode(“hello world”); var container = document.createElement(“p”); container.appendChild(mes); document.body.appendChild(container);
2、復制節(jié)點
cloneNode(boolean):
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的區(qū)別 document.body.appendChild(newpara );
注意:
◆true的話:是<p>aaaa</p>克隆。
◆false: 只克隆 <p></p>,里面的文本不克隆。
◆可以自己寫個例子,然后用firebug看看。
克隆后的新節(jié)點,和createTextNode()一樣 不會被自動插入到文檔 。需要appendChild();另外還有一個注意: 如果克隆后,id一樣,不要忘記用 setAttribute(“id” , “ another_id “);改變新的節(jié)點的ID。
3、插入節(jié)點
appendChild() :
var container = document.createElement("p"); var t = document.createTextNode("cssrain"); container.appendChild(t); document.body.appendChild(container);
它經常跟createElement()和createTextNode(),cloneNode()配合使用。另外appendChild()不僅可以用來追加新的元素,也可以你挪動文檔中現(xiàn)有的元素??聪旅娴睦樱?/p>
<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> //發(fā)現(xiàn)msg放到 content 后面去了。 <p id="content"> content <p id="msg">msg</p> </p> <p id="aaa">aaaaaaaa</p>
第二個參數(shù)是可選,如果第二個參數(shù)不寫,將默認添加到文檔的***,相當于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> // 我們發(fā)現(xiàn)ID為msg的 插入到了aaa的前面。
Js內部處理方式跟 appendChild()相似。
4、刪除節(jié)點
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>
如果不知道要刪除的節(jié)點的父節(jié)點是什么?可以使用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>
注意:你如果想把某個節(jié)點從一處移動到另一個地方,不必使用removeChild()??梢允褂们懊娴?appendChild()和insertBefore(),他們都會自動先刪除節(jié)點,然后移動到你指定的地方。、
5、替換節(jié)點
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>
6、設置/獲取屬性節(jié)點
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”) ){ }
7、查找節(jié)點
getElementById();
返回一個對象,對象擁有 nodeName , nodeType , parentNode , ChildNodes 等屬性。getElementsByTagName():查找標簽名的所有元素。返回一個集合,可以用循環(huán)取出每個對象,對象擁有 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>
8、DOM屬性
我們常用的3中類型:
nodeType == 1 : 元素節(jié)點
nodeType == 2 : 屬性節(jié)點
nodeType == 3 : 文本節(jié)點
如果想記住的話,上面的順序我們可以看做是從前到后。比如:<p title="cssrain" >test</p> 從前往后讀:你會發(fā)現(xiàn)先是元素節(jié)點,然后是屬性節(jié)點,***是文本節(jié)點,這樣你就很容易記住了nodeType分別代表什么類型了。nodeType屬性經常跟if配合使用,以確保不會在錯誤的節(jié)點類型上執(zhí)行錯誤的操作。比如:
function cs_demo(mynode){ if(mynode.nodeType == 1){ mynode.setAttribute("title","demo"); } }
代碼解釋:先檢查mynode的nodeType屬性,以確保它所代表的節(jié)點確實是一個元素節(jié)點。和nodeName屬性一樣,他也是只讀屬性,不能進行設置.
<div id="c">aaaaaaaaaaaaaaaa</div> <SCRIPT LANGUAGE="JavaScript"> var c= document.getElementById("c"); alert( c.nodeValue );//返回null </SCRIPT>
nodeValue是一個可以讀、寫的屬性。 但它不能設置元素節(jié)點的值??聪旅娴睦樱?/p>
<div id="c">aaaaaaaaaaaaaaaa</div> <SCRIPT LANGUAGE="JavaScript"> var c= document.getElementById("c"); c.nodeValue =" dddddddddddd"; //不能設置 //alert( c.firstChild.nodeValue ) //元素節(jié)點 包括屬性節(jié)點和文本節(jié)點。 c.firstChild.nodeValue = "test"//能設置 </SCRIPT>
當然我們?yōu)榱舜_保能正確運行:可以加一段代碼:
<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 ){ //判斷是不是 文本節(jié)點 c.firstChild.nodeValue = "test"//能設置 } </SCRIPT>
nodeValue一般只用來設置 文本節(jié)點的值。如果要刷新屬性節(jié)點的值,一般使用setAttribute(). childNodes屬性:返回一個數(shù)組,數(shù)組由元素節(jié)點的子節(jié)點構成。由于文本節(jié)點和屬性節(jié)點都不可能再包含任何子節(jié)點,所以他們的childNodes屬性永遠返回一個空數(shù)組。
可以使用hasChildNodes方法,它用來判斷某個元素有沒有子節(jié)點。或者if (container.childNodes.length < 1) ;childNodes也是一個只讀屬性。如果要增加節(jié)點,可以使用appendChild()或者insertBefore() ,刪除節(jié)點可以使用removeChild(); 操作后,childNodes屬性會自動刷新。
firstChild屬性
由于文本節(jié)點和屬性節(jié)點都不可能再包含任何子節(jié)點,所以他們的firstChild屬性永遠返回一個空數(shù)組。 如果沒有子節(jié)點,將返回null;node.firstChild 等價于 node.childNodes[0] ; firstChild屬性是一個只讀屬性。
lastChild屬性
由于文本節(jié)點和屬性節(jié)點都不可能再包含任何子節(jié)點,所以他們的lastChild屬性永遠返回一個空數(shù)組。 如果沒有子節(jié)點,將返回null; node.lastChild 等價于 node.childNodes[ node.childNodes.length - 1 ] ;lastChild屬性是一個只讀屬性。
nextSibling屬性
返回目標節(jié)點的下一個兄弟節(jié)點。如果目標節(jié)點后面沒有同屬于一個父節(jié)點的節(jié)點,nextSibling 將返回null ;nextSibling 屬性是一個只讀屬性。
previousSibling屬性
返回目標節(jié)點的前一個兄弟節(jié)點。如果目標節(jié)點前面沒有同屬于一個父節(jié)點的節(jié)點,previousSibling 將返回null ;previousSibling 屬性是一個只讀屬性。
parentNode屬性
注:parentNode屬性返回的節(jié)點永遠是一個元素節(jié)點,因為只有元素節(jié)點才有可能有子節(jié)點。
當然有個例外
document節(jié)點,他沒有父節(jié)點。所以document節(jié)點的parentNode屬性將返回null;parentNode 屬性是一個只讀屬性。
關于JavaScript中BOM和DOM有什么區(qū)別就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。