国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

深入解讀JavaScript中BOM和DOM

開發(fā) 前端
本文應(yīng)用了很多實(shí)例,來解讀JavaScript中BOM和DOM,DOM是一個使程序和腳本有能力動態(tài)地訪問和更新文檔的內(nèi)容、結(jié)構(gòu)以及樣式的平臺和語言中立的接口。,而BOM定義了JavaScript可以進(jìn)行操作的瀏覽器的各個功能部件的接口。

51CTO之前曾報(bào)導(dǎo)過關(guān)于JavaScript使用心得匯總:從BOM和DOM談起,在那篇文章中,主要介紹了兩者的基本概念,而本文應(yīng)用了很多實(shí)例,來解讀JavaScript中BOM和DOM。

BOM定義了JavaScript可以進(jìn)行操作的瀏覽器的各個功能部件的接口,提供訪問文檔各個功能部件(如窗口本身、屏幕功能部件、瀏覽歷史記錄等)的途徑以及操作方法。

遺憾的是,BOM只是JavaScript腳本實(shí)現(xiàn)的一部分,沒有任何相關(guān)的標(biāo)準(zhǔn),每種瀏覽器都有自己的BOM實(shí)現(xiàn),這可以說是BOM的軟肋所在通常情況下瀏覽器特定的JavaScript擴(kuò)展都被看作BOM的一部分,主要包括:

◆關(guān)閉、移動瀏覽器及調(diào)整瀏覽器窗口大小;
◆彈出新的瀏覽器窗口;
◆提供瀏覽器詳細(xì)信息的定位對象;
◆提供載入到瀏覽器窗口的文檔詳細(xì)信息的定位對象;
◆提供用戶屏幕分辨率詳細(xì)信息的屏幕對象;
◆提供對cookie的支持;
◆加入ActiveXObject類擴(kuò)展BOM,通過JavaScript實(shí)例化ActiveX對象。

BOM有一些事實(shí)上的標(biāo)準(zhǔn),如窗口對象、導(dǎo)航對象等,但每種瀏覽器都為這些對象定義或擴(kuò)展了屬性及方法。Document Object Model,這個就是標(biāo)準(zhǔn)了,由著名的w3c制定,目前***的級別是level 3,不過3還沒有徹底完成。

目前主流的瀏覽器都可以支持到(僅僅是支持到哦,并不是完全遵守的)level 2,對html,也就是html4.x,目前***的是4.01,后來w3c向把html統(tǒng)一向xml靠攏,于是就有了xhtml1.0,再后來,w3c想搞一個xhtml2.0,結(jié)果進(jìn)度緩慢,加之各大廠商又不看好,于是就有了html5.0

1、創(chuàng)建節(jié)點(diǎn)

  1. createElement():   
  2. var a  = document.createElement(“p”);  

它創(chuàng)建的是一個元素節(jié)點(diǎn),所以nodeType等于1,a.nodeName將返回p。

注意;createElement()方法創(chuàng)建出來的新元素節(jié)點(diǎn)不會被自動添加到文檔里,既然沒添加到文檔里,說明它還是一個游離的狀態(tài)。所以它也沒有nodeParent屬性。如果想把它添加到文檔里,可以使用 appendChild()或者insertBefore()方法或者replaceChild()方法。當(dāng)然我們在前面的例子中,自己寫了一個 insertAfter()方法,比如:

  1. var a  = document.createElement(“p”);   
  2. document.body.appendChild(a);  

注意: appendChild()默認(rèn)是添加到文檔的***。也就是lastChild子節(jié)點(diǎn)。如果想添加到某個地方,可以使用insertBefore()。如果想在元素插入之前給元素添加屬性。可以這么做:

  1. var a  = document.createElement(“p”);   
  2. a.setAttribute(“title”,”my demo”);   
  3. document.body.appendChild(a);   
  4. createTextNode():   
  5. var b = document.createTextNode(“my demo”);  

它創(chuàng)建的是一個文本節(jié)點(diǎn),所以nodeType等于3 。b.nodeName 將返回 #text ; 跟createElement()一樣,用createTextNode()創(chuàng)建的節(jié)點(diǎn)也不會自動添加到文檔里。需要使用 appendChild()或者insertBefore()方法或者replaceChild()方法。它經(jīng)常與createElement()配合使用,知道為什么嗎?(一個元素節(jié)點(diǎn),一個文本節(jié)點(diǎn)。)

  1. var mes = document.createTextNode(“hello world”);   
  2. var container = document.createElement(“p”);   
  3. container.appendChild(mes);   
  4. document.body.appendChild(container);  

2、復(fù)制節(jié)點(diǎn)

cloneNode(boolean):

  1. var mes = document.createTextNode("hello world");   
  2. var container = document.createElement("p");   
  3. container.appendChild(mes);   
  4. document.body.appendChild(container);   
  5. var newpara = container.cloneNode(true);//true和false的區(qū)別   
  6. document.body.appendChild(newpara );  

注意:
 
◆true的話:是<p>aaaa</p>克隆。
◆false: 只克隆 <p></p>,里面的文本不克隆。
◆可以自己寫個例子,然后用firebug看看。

克隆后的新節(jié)點(diǎn),和createTextNode()一樣  不會被自動插入到文檔 。需要appendChild();另外還有一個注意: 如果克隆后,id一樣,不要忘記用 setAttribute(“id” , “ another_id “);改變新的節(jié)點(diǎn)的ID。

#p#

3、插入節(jié)點(diǎn)

appendChild() :

  1. var container = document.createElement("p");   
  2. var t =  document.createTextNode("cssrain");   
  3. container.appendChild(t);   
  4. document.body.appendChild(container);  

它經(jīng)常跟createElement()和createTextNode(),cloneNode()配合使用。另外appendChild()不僅可以用來追加新的元素,也可以你挪動文檔中現(xiàn)有的元素。看下面的例子:

  1. <p id="msg">msg</p>   
  2. <p id="content">content</p>   
  3. <p id="aaa">aaaaaaaa</p>   
  4. <script>   
  5. var mes = document.getElementById("msg");   
  6. var container = document.getElementById("content");   
  7. container.appendChild(mes);   
  8. </script>   
  9. //發(fā)現(xiàn)msg放到 content 后面去了。  
  10. <p id="content">   
  11. content   
  12. <p id="msg">msg</p>   
  13. </p>   
  14. <p id="aaa">aaaaaaaa</p>  

第二個參數(shù)是可選,如果第二個參數(shù)不寫,將默認(rèn)添加到文檔的***,相當(dāng)于appendChild();我們看看insertBefore()怎么使用:

  1. <div id="cssrian">   
  2. <p id="content">1111</p>   
  3. <div id="msg">msg<div>test</div></div>   
  4. <p id="content">222</p>   
  5. <p id="aaa">aaaaaaaa</p>   
  6. </div>   
  7. <script>   
  8. var msg = document.getElementById("msg");   
  9. var aaa = document.getElementById("aaa");   
  10. var test = document.getElementById("cssrian");   
  11. test.insertBefore( msg , aaa );   
  12. </script>   
  13. // 我們發(fā)現(xiàn)ID為msg的 插入到了aaa的前面。 

Js內(nèi)部處理方式跟 appendChild()相似。

4、刪除節(jié)點(diǎn)

removeChild():

  1. <body>   
  2. <div id="cssrain">   
  3. <div id="a"></div>   
  4. <div id="b"></div>   
  5. <div id="c"></div>   
  6. </div>   
  7. </body>   
  8. <script>   
  9. var msg = document.getElementById("cssrain");   
  10. var b = document.getElementById("b");   
  11. msg.removeChild(b);   
  12. </script>  

如果不知道要刪除的節(jié)點(diǎn)的父節(jié)點(diǎn)是什么?可以使用parentNode屬性。比如:

  1. <body>   
  2. <div id="cssrain">   
  3. <div id="a"></div>   
  4. <div id="b"></div>   
  5. <div id="c"></div>   
  6. </div>   
  7. </body>   
  8. <script>   
  9. var b = document.getElementById("b");   
  10. var c = b.parentNode;   
  11. c.removeChild(b);   
  12. </script>  

注意:你如果想把某個節(jié)點(diǎn)從一處移動到另一個地方,不必使用removeChild()。可以使用前面的 appendChild()和insertBefore(),他們都會自動先刪除節(jié)點(diǎn),然后移動到你指定的地方。、

5、替換節(jié)點(diǎn)

  1. Element.repalceChild( newNode , oldNode ):  
  2.  
  3. <body>   
  4. <div id="cssrain">   
  5. <div id="a"></div>   
  6. <div id="b"></div>   
  7. <div id="c"></div>   
  8. </div>   
  9. </body>   
  10. <script>   
  11. var cssrain = document.getElementById("cssrain");   
  12. var msg =  document.getElementById("b");   
  13. var para =  document.createElement("p");   
  14. cssrain.replaceChild( para , msg  );   
  15. </script>  

#p#

6、設(shè)置/獲取屬性節(jié)點(diǎn)

  1. setAttribute();//設(shè)置   
  2.  
  3. var a  = document.createElement(“p”);   
  4. a.setAttribute(“title”,”my demo”);   
  5.  
  6. var a =document.getElementById(“cssrain”);   
  7. var b = a.getAttribute(“title”);  

獲取的時候,如果屬性不存在,則返回空,注意ie和ff返回不同,可以看我以前的例子。 返回雖然不同,但是可以用一個方法來判斷:if(a.getAttribute(“title”) ){   }

7、查找節(jié)點(diǎn)

getElementById();

返回一個對象,對象擁有 nodeName , nodeType , parentNode , ChildNodes 等屬性。getElementsByTagName():查找標(biāo)簽名的所有元素。返回一個集合,可以用循環(huán)取出每個對象,對象擁有 nodeName , nodeType , parentNode , ChildNodes 等屬性。 例子:

  1. var ps = document.getElementsByTagName(“p”);   
  2. for(var i=0 ; i< ps.length ; i++){   
  3.  ps[i].setAttribute(“title”,”hello”);   
  4. //也可以使用:  ps.item(i).setAttribute("title","hello");   
  5. }   
  6.    
  7. <body>   
  8. <div id="cssrain">   
  9. <div id="a"></div>   
  10. <div id="b"></div>   
  11. <div id="c"></div>   
  12. </div>   
  13. </body>   
  14. <script>   
  15. var ps = document.getElementById("cssrain")   
  16. if(ps.hasChildNodes){   
  17.         alert( ps.childNodes.length  );     
  18. }   
  19. </script>  

8、DOM屬性

我們常用的3中類型:
 
nodeType == 1  : 元素節(jié)點(diǎn)
nodeType == 2  : 屬性節(jié)點(diǎn)
nodeType == 3  : 文本節(jié)點(diǎn)

如果想記住的話,上面的順序我們可以看做是從前到后。比如:<p  title="cssrain" >test</p> 從前往后讀:你會發(fā)現(xiàn)先是元素節(jié)點(diǎn),然后是屬性節(jié)點(diǎn),***是文本節(jié)點(diǎn),這樣你就很容易記住了nodeType分別代表什么類型了。nodeType屬性經(jīng)常跟if配合使用,以確保不會在錯誤的節(jié)點(diǎn)類型上執(zhí)行錯誤的操作。比如:

  1. function cs_demo(mynode){   
  2.       if(mynode.nodeType == 1){   
  3.               mynode.setAttribute("title","demo");   
  4.         }   
  5. }  

代碼解釋:先檢查mynode的nodeType屬性,以確保它所代表的節(jié)點(diǎn)確實(shí)是一個元素節(jié)點(diǎn)。和nodeName屬性一樣,他也是只讀屬性,不能進(jìn)行設(shè)置.

  1. <div id="c">aaaaaaaaaaaaaaaa</div>   
  2. <SCRIPT LANGUAGE="JavaScript">   
  3. var cdocument.getElementById("c");   
  4. alert(  c.nodeValue  );//返回null   
  5. </SCRIPT>  

nodeValue是一個可以讀、寫的屬性。 但它不能設(shè)置元素節(jié)點(diǎn)的值。看下面的例子:

  1. <div id="c">aaaaaaaaaaaaaaaa</div>   
  2. <SCRIPT LANGUAGE="JavaScript">   
  3. var cdocument.getElementById("c");   
  4.   c.nodeValue =" dddddddddddd"; //不能設(shè)置   
  5.   //alert( c.firstChild.nodeValue ) //元素節(jié)點(diǎn) 包括屬性節(jié)點(diǎn)和文本節(jié)點(diǎn)。   
  6.   c.firstChild.nodeValue =  "test"//能設(shè)置   
  7. </SCRIPT>  

當(dāng)然我們?yōu)榱舜_保能正確運(yùn)行:可以加一段代碼:

  1. <div id="c">aaaaaaaaaaaaaaaa</div>   
  2. <SCRIPT LANGUAGE="JavaScript">   
  3. var cdocument.getElementById("c");   
  4.   c.nodeValue =" dddddddddddd"; //不能設(shè)置   
  5.   //alert( c.firstChild.nodeValue )   
  6.   if( c.firstChild.nodeType==3 ){ //判斷是不是 文本節(jié)點(diǎn)   
  7.   c.firstChild.nodeValue =  "test"//能設(shè)置   
  8.   }   
  9. </SCRIPT>  

nodeValue一般只用來設(shè)置 文本節(jié)點(diǎn)的值。如果要刷新屬性節(jié)點(diǎn)的值,一般使用setAttribute(). childNodes屬性:返回一個數(shù)組,數(shù)組由元素節(jié)點(diǎn)的子節(jié)點(diǎn)構(gòu)成。由于文本節(jié)點(diǎn)和屬性節(jié)點(diǎn)都不可能再包含任何子節(jié)點(diǎn),所以他們的childNodes屬性永遠(yuǎn)返回一個空數(shù)組。

可以使用hasChildNodes方法,它用來判斷某個元素有沒有子節(jié)點(diǎn)。或者if (container.childNodes.length < 1) ;childNodes也是一個只讀屬性。如果要增加節(jié)點(diǎn),可以使用appendChild()或者insertBefore() ,刪除節(jié)點(diǎn)可以使用removeChild(); 操作后,childNodes屬性會自動刷新。

firstChild屬性

由于文本節(jié)點(diǎn)和屬性節(jié)點(diǎn)都不可能再包含任何子節(jié)點(diǎn),所以他們的firstChild屬性永遠(yuǎn)返回一個空數(shù)組。 如果沒有子節(jié)點(diǎn),將返回null;node.firstChild 等價于  node.childNodes[0] ; firstChild屬性是一個只讀屬性。

lastChild屬性

由于文本節(jié)點(diǎn)和屬性節(jié)點(diǎn)都不可能再包含任何子節(jié)點(diǎn),所以他們的lastChild屬性永遠(yuǎn)返回一個空數(shù)組。 如果沒有子節(jié)點(diǎn),將返回null; node.lastChild  等價于  node.childNodes[ node.childNodes.length - 1 ] ;lastChild屬性是一個只讀屬性。

nextSibling屬性

返回目標(biāo)節(jié)點(diǎn)的下一個兄弟節(jié)點(diǎn)。如果目標(biāo)節(jié)點(diǎn)后面沒有同屬于一個父節(jié)點(diǎn)的節(jié)點(diǎn),nextSibling 將返回null ;nextSibling 屬性是一個只讀屬性。

previousSibling屬性

返回目標(biāo)節(jié)點(diǎn)的前一個兄弟節(jié)點(diǎn)。如果目標(biāo)節(jié)點(diǎn)前面沒有同屬于一個父節(jié)點(diǎn)的節(jié)點(diǎn),previousSibling 將返回null ;previousSibling 屬性是一個只讀屬性。

parentNode屬性

注:parentNode屬性返回的節(jié)點(diǎn)永遠(yuǎn)是一個元素節(jié)點(diǎn),因?yàn)橹挥性毓?jié)點(diǎn)才有可能有子節(jié)點(diǎn)。

當(dāng)然有個例外

document節(jié)點(diǎn),他沒有父節(jié)點(diǎn)。所以document節(jié)點(diǎn)的parentNode屬性將返回null;parentNode 屬性是一個只讀屬性。
 

【編輯推薦】

  1. JavaScript使用心得匯總:從BOM和DOM談起
  2. 關(guān)于使用JavaScript的幾點(diǎn)建議
  3. 早該知道的7個JavaScript技巧
責(zé)任編輯:王曉東 來源: 博客園
相關(guān)推薦

2009-08-26 13:31:21

JavaScript使

2021-09-09 10:26:26

Javascript 文檔對象前端

2010-09-28 09:14:36

HTML DOMJavascript

2010-09-28 14:35:34

DOM遍歷

2011-07-04 13:12:04

JavaScript

2011-01-18 14:06:58

JavaScriptweb

2015-12-24 10:05:39

JavaScripttypeofinstanceof

2024-11-07 09:08:58

2010-09-28 12:59:45

JavaScriptDOM

2010-08-17 15:04:37

JavaScriptDOM ready

2010-09-08 16:50:11

JavaScriptDOM操作

2010-09-08 15:13:09

Node節(jié)點(diǎn)Node屬性

2010-09-08 17:26:46

JavaScript

2010-09-28 14:12:50

Javascript

2009-12-15 14:16:13

Ruby Contin

2023-05-12 08:11:58

JavaScriptJSON克隆

2021-02-05 07:33:05

JavaScript參數(shù)ES6

2010-09-28 13:24:34

DOM文檔對象模型

2010-09-28 09:22:34

DOM模型Html

2016-04-06 11:29:58

JavaScriptDOM操作
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

黑人巨大精品欧美一区二区一视频 | 伊人夜夜躁av伊人久久| 国产av国片精品| 91日韩精品一区| 九色porny91| 欧美日韩人人澡狠狠躁视频| 四虎影视2018在线播放alocalhost| 一本久道久久综合中文字幕 | 九九在线精品| 久久精品国产精品青草色艺| 成人免费毛片app| 大j8黑人w巨大888a片| 菠萝蜜视频在线观看一区| 免费在线黄色av| 精品国产乱码久久久久久影片| 欧美知名女优| 国产亚洲欧美日韩美女| √天堂8在线网| 久久国产日韩欧美精品| 九九视频这里只有精品| 欧美一区二区视频在线| 亚洲精品动态| 亚洲欧美成人一区二区三区| 黄污在线观看| 欧美三级免费观看| 黄色免费在线观看网站| 精品美女一区二区| 九九久久国产| 日韩av电影国产| 99久久亚洲精品蜜臀| 蜜桃视频在线观看91| 成人精品一区二区三区四区| 国产v亚洲v天堂无码久久久 | 亚洲综合一区二区精品导航| 国产专区在线播放| 日韩电影中文字幕一区| 91精品啪在线观看国产手机| 久久男女视频| 国模私拍视频| 在线精品视频免费播放| 亚洲精品一区二区三区中文字幕 | 欧美嫩在线观看| 久久免费一级片| 亚洲人成电影在线播放| 亚洲视频第一页| 欧美高清在线视频观看不卡| 国产精品扒开腿做| 特级西西444www大精品视频| 久久在线观看视频| 日韩视频久久| 男人艹女人网站| 日韩中文字幕第一页| 嫩草成人www欧美| 国产h视频在线观看| 欧美日本精品一区二区三区| 欧美激情在线免费| 国产在线一二三区| 国产精品视频免费一区| 欧美电影影音先锋| 日日嗨av一区二区三区四区| 日本欧美日韩| 69国产精品视频| 亚洲电影在线看| 日韩av首页| 国产另类自拍| 樱桃国产成人精品视频| 国产乱理伦片a级在线观看| 91精品一区二区三区久久久久久| 91女主播在线观看| 久久伊人精品一区二区三区| 日韩久久久久| 轻轻色免费在线视频| 亚洲 国产 欧美一区| 亚洲一区二区三区自拍| 欧美韩日一区| www.中文字幕在线| 日韩成人网免费视频| 亚洲看片一区| 外国精品视频在线观看| 青青在线视频一区二区三区| 91免费观看视频| 欧美日韩破处| 亚洲人成77777男人| 亚洲视频在线免费看| 欧美中文一区二区| 日韩精品伦理第一区| 污片在线观看一区二区| 久久精品免视看国产成人| 国产精品视频福利| 亚洲色图av在线| 久久久精品久久久| 91久久精品一区二区别| 99久久久精品免费观看国产| 欧美日韩精品久久| 久久美女福利视频| 四虎在线免费观看| 国内激情视频在线观看| 精品福利一区| 亚洲免费成人| 国产三级欧美三级日产三级99| 欧美主播一区二区三区美女| 久久久精品日本| 91视频-88av| 69sex久久精品国产麻豆| 宅男深夜国产| 欧美中文字幕精在线不卡| 国内成人精品| 中文字幕这里只有精品| 欧美在线观看视频一区| 成人黄色小视频在线观看| 午夜精品一区在线观看| 亚洲欧洲国产精品| 久热精品视频在线观看| 亚洲欧美日本另类| 久久精品视频va| 欧美成人免费观看| 51久久精品夜色国产麻豆| 清纯唯美亚洲激情| 96sao精品视频在线观看| 国产日产精品一区二区三区四区| 国产精品一区二| 国产一级不卡视频| free性欧美1819hd| 久久一卡二卡| 精品久久ai电影| aⅴ色国产欧美| 激情综合网天天干| 亚洲一区自拍偷拍| 在线不卡免费欧美| 久久国产精品视频| 欧美孕妇性xx| 国产欧美日韩亚洲| 久久777国产线看观看精品| 亚洲精品之草原avav久久| 六月丁香婷婷色狠狠久久| 欧美日韩亚洲一区二| 岛国av一区二区| av网站免费线看精品| av成人资源网| a毛片在线看免费观看| 337p日本欧洲亚洲大胆鲁鲁| 精品自拍一区| 国产香蕉久久| 欧美精品网站| 亚洲精品菠萝久久久久久久| 亚洲国产精品视频在线观看| 中文字幕视频在线免费欧美日韩综合在线看| 操人视频在线观看欧美| 国产一区二区高清视频| 亚洲天堂男人天堂| 99国产超薄丝袜足j在线观看| 日韩欧美猛交xxxxx无码| 国产毛片久久久久久国产毛片| 亚洲一区在线直播| 91免费国产精品| 国产高清精品在线观看| 人妻少妇精品无码专区二区 | 一区二区三区精品国产| 国产乱码精品一区二区三区中文| 91在线视频一区| 国内精品美女av在线播放| 亚洲网址你懂得| 日产精品久久久一区二区福利| 色综合激情久久| 亚洲国产日产av| 亚洲天堂av老司机| 国产欧美一区二区精品性色| 天堂在线中文资源| 精品日本一区二区| 风间由美一区二区av101| 日韩精品1区2区3区| 亚洲欧美在线第一页| 国产精品成久久久久三级| 精品少妇在线视频| av在线免费观看网站| 麻豆视频在线观看免费网站| 免费在线黄色影片| 99免在线观看免费视频高清| av片中文字幕| 18禁男女爽爽爽午夜网站免费| 亚洲资源在线网| 精品无码国模私拍视频| 成人三级小说| 丝袜美腿综合| 欧美福利专区| 久久福利影视| 欧美 日韩 国产 一区| 欧美久久一级| 偷拍欧美精品| 国产精品久久占久久| 久久久久久久久久久妇女 | 高清国产一区二区| 精品久久一区二区| 欧美日韩激情四射| 中文字幕一区二区三区四区久久| 久久精品欧美日韩精品| 欧美一级大片在线观看| 青青青手机在线视频观看| 欧美在线91| 国产精品麻豆视频|