日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
深入解讀JavaScript中BOM和DOM

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

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

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

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

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

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

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

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

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

注意;createElement()方法創(chuàng)建出來的新元素節(jié)點(diǎn)不會(huì)被自動(dòng)添加到文檔里,既然沒添加到文檔里,說明它還是一個(gè)游離的狀態(tài)。所以它也沒有nodeParent屬性。如果想把它添加到文檔里,可以使用 appendChild()或者insertBefore()方法或者replaceChild()方法。當(dāng)然我們?cè)谇懊娴睦又校约簩懥艘粋€(gè) insertAfter()方法,比如:

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

注意: appendChild()默認(rèn)是添加到文檔的***。也就是lastChild子節(jié)點(diǎn)。如果想添加到某個(gè)地方,可以使用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)建的是一個(gè)文本節(jié)點(diǎn),所以nodeType等于3 。b.nodeName 將返回 #text ; 跟createElement()一樣,用createTextNode()創(chuàng)建的節(jié)點(diǎn)也不會(huì)自動(dòng)添加到文檔里。需要使用 appendChild()或者insertBefore()方法或者replaceChild()方法。它經(jīng)常與createElement()配合使用,知道為什么嗎?(一個(gè)元素節(jié)點(diǎn),一個(gè)文本節(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的話:是

aaaa

克隆。
◆false: 只克隆

,里面的文本不克隆。
◆可以自己寫個(gè)例子,然后用firebug看看。

克隆后的新節(jié)點(diǎn),和createTextNode()一樣  不會(huì)被自動(dòng)插入到文檔 。需要appendChild();另外還有一個(gè)注意: 如果克隆后,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()不僅可以用來追加新的元素,也可以你挪動(dòng)文檔中現(xiàn)有的元素??聪旅娴睦樱?/p>

 
 
 
  1. msg

       
  2. content

       
  3. aaaaaaaa

       
  4.    
  5. //發(fā)現(xiàn)msg放到 content 后面去了。  
  6.    
  7. content   
  8. msg

       
  9.    
  10. aaaaaaaa

      

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

 
 
 
  1.    
  2. 1111

       
  3. msg
    test
   
  • 222

       
  • aaaaaaaa

       
  •    
  •    
  • // 我們發(fā)現(xiàn)ID為msg的 插入到了aaa的前面。 
  • Js內(nèi)部處理方式跟 appendChild()相似。

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

    removeChild():

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

     
     
     
    1.    
    2.    
       
  •    
  •    
  •    
  •    
  •   
  • 注意:你如果想把某個(gè)節(jié)點(diǎn)從一處移動(dòng)到另一個(gè)地方,不必使用removeChild()??梢允褂们懊娴?appendChild()和insertBefore(),他們都會(huì)自動(dòng)先刪除節(jié)點(diǎn),然后移動(dòng)到你指定的地方。、

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

     
     
     
    1. Element.repalceChild( newNode , oldNode ):  
    2.  
    3.    
    4.    
       
  •    
  • c    
  •    
  •    
  •   
  • #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”);  

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

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

    getElementById();

    返回一個(gè)對(duì)象,對(duì)象擁有 nodeName , nodeType , parentNode , ChildNodes 等屬性。getElementsByTagName():查找標(biāo)簽名的所有元素。返回一個(gè)集合,可以用循環(huán)取出每個(gè)對(duì)象,對(duì)象擁有 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.    
    8.    
    9. a    
    10. b    
    11. c    
    12.    
    13.    
    14.   

    8、DOM屬性

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

    如果想記住的話,上面的順序我們可以看做是從前到后。比如:test

    從前往后讀:你會(huì)發(fā)現(xiàn)先是元素節(jié)點(diǎn),然后是屬性節(jié)點(diǎn),***是文本節(jié)點(diǎn),這樣你就很容易記住了nodeType分別代表什么類型了。nodeType屬性經(jīng)常跟if配合使用,以確保不會(huì)在錯(cuò)誤的節(jié)點(diǎn)類型上執(zhí)行錯(cuò)誤的操作。比如:

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

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

     
     
     
    1. aaaaaaaaaaaaaaaa   
    2.   

    nodeValue是一個(gè)可以讀、寫的屬性。 但它不能設(shè)置元素節(jié)點(diǎn)的值??聪旅娴睦樱?/p>

     
     
     
    1. aaaaaaaaaaaaaaaa   
    2.   

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

     
     
     
    1. aaaaaaaaaaaaaaaa   
    2.   

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

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

    firstChild屬性

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

    lastChild屬性

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

    nextSibling屬性

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

    previousSibling屬性

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

    parentNode屬性

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

    當(dāng)然有個(gè)例外

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

    【編輯推薦】

    1. JavaScript使用心得匯總:從BOM和DOM談起
    2. 關(guān)于使用JavaScript的幾點(diǎn)建議
    3. 早該知道的7個(gè)JavaScript技巧

    網(wǎng)站欄目:深入解讀JavaScript中BOM和DOM
    鏈接地址:http://www.5511xx.com/article/cdsjepc.html

    其他資訊