JavaScript操作DOM對象詳解
一、DOM基礎(chǔ)
DOM(Document Object Model)即文檔對象模型,針對HTML和XML文檔的API(應(yīng)用程序接口)。DOM描繪了一個層次化的節(jié)點樹,運行開發(fā)人員添加、移除和修改頁面的某一部分。DOM中的三個字母,D(文檔)可以理解為整個Web加載的網(wǎng)頁文檔;O(對象)可以理解為類似Window對象之類的東西,可以調(diào)用屬性和方法,這里我們說的是document對象;M(模型)可以理解為網(wǎng)頁文檔的樹型結(jié)構(gòu)。
1、節(jié)點
加載HTML頁面時,Web瀏覽器生成一個樹型結(jié)構(gòu),用來表示頁面內(nèi)部結(jié)構(gòu)。DOM將這種樹型結(jié)構(gòu)理解為由節(jié)點組成。
從上圖的樹型結(jié)構(gòu),我們理解幾個概念,html標簽沒有父輩,沒有兄弟,所以html標簽為根標簽。head標簽是html標簽的子標簽,meta和title標簽之間是兄弟關(guān)系。如果把每個標簽當(dāng)做一個節(jié)點的話,那么這些節(jié)點組合成了一棵節(jié)點樹。
注:后面我們經(jīng)常把標簽稱作為元素,是一個意思。
2、節(jié)點種類
示例:
<div title="屬性節(jié)點">測試Div</div>
節(jié)點分為三類:
- 1、元素節(jié)點:其實就是標簽,即:<div></div>
- 2、文本節(jié)點:其實就是標簽內(nèi)的純文本,即:測試Div
- 3、屬性節(jié)點:其實就是標簽的屬性,即:title=“屬性節(jié)點”
二、查找元素
W3C提供了比較方便簡單的定位節(jié)點的方法和屬性,以便我們快速的對節(jié)點進行操作,分別為getElementById()、getElementsByTagName()、getElementsByName()、getAttribute()、setAttribute()和removeAttribute()。
元素節(jié)點方法
方法 | 說明 |
getElementById() | 獲取特點ID元素的節(jié)點 |
getElementsByTagName() | 獲取相同元素的節(jié)點列表 |
getElementsByName() | 獲取相同名稱的節(jié)點列表 |
getAttribute() | 獲取特點元素節(jié)點屬性的值 |
setAttribute() | 設(shè)置特點元素節(jié)點屬性的值 |
removeAttribute() | 移除特定元素節(jié)點屬性 |
1、getElementById()
getElementById()方法,接受一個參數(shù):要獲取的元素的ID。如果找到相應(yīng)的元素則返回該元素的HTMLDivElement對象,如果不存在,則返回null。
示例:
???? var box=document.getElementById('box');?????????? //獲取id為box的元素節(jié)點 ???? alert(box);
上面的例子,默認情況返回null,這無關(guān)是否存在id='box'的標簽,而是執(zhí)行順序問題。
注:DOM操作必須等待HTML文檔全部加載完畢以后,才可以獲取元素。
解決方法:
1、把script調(diào)用標簽移到html末尾即可;
2、使用onload事件來處理JS,等待html加載完畢再加載onload事件里面的JS。
?? window.onload=function(){ ??????? //這里存放當(dāng)網(wǎng)頁所有內(nèi)容都加載完畢后,再執(zhí)行的代碼 ??? };
上面的代碼可以改為:
window.onload=function(){ var box=document.getElementById('box'); //預(yù)加載html后執(zhí)行 alert(box); };
注:id表示一個元素節(jié)點的唯一性,不能同時給兩個或以上的元素節(jié)點創(chuàng)建同一個命名的id。某些低版本的瀏覽器會無法識別getElementById()方法,這時需要做一些判斷:
?? if(document.getElementById){???? //判斷是否支持getElementById ??????? alert('但前瀏覽器支持getElementById'); ??? }
上面例子中的代碼最終修改為:
?window.onload=function(){ ???? if(document.getElementById){ ?????????????? var box=document.getElementById('box'); ????????????? ?alert(box); ????? }else{ ?????????????? alert('瀏覽器不兼容,請更換瀏覽器'); ??????} };
當(dāng)我們通過getElementById()獲取到特定元素節(jié)點時,這個節(jié)點對象就被我們獲取到了,而通過這個節(jié)點對象,我們可以訪問它的一系列屬性。
元素節(jié)點屬性
屬性 | 說明 |
tagName | 獲取元素節(jié)點的標簽名 |
innerHTML | 獲取元素節(jié)點里的內(nèi)容(即純文本),非W3C DOM規(guī)范 |
示例:
document.getElementById('box').tagName; //獲取這個元素節(jié)點的標簽名 輸出DIV document.getElementById('box').innerHTML; //獲取這個元素節(jié)點里面的文本(包含HTML標簽)
HTML屬性的屬性
屬性 | 說明 |
id | 元素節(jié)點的id名稱 |
title | 元素節(jié)點的title屬性值 |
style | CSS內(nèi)聯(lián)樣式屬性值 |
className | CSS元素的類 |
示例:
window.onload=function(){ ??? var box=document.getElementById('box'); ????alert(box.id);?????????????????? //獲取這個元素節(jié)點id屬性的值,注意;不是屬性節(jié)點 ??? alert(box.title);??????????????? //獲取title屬性的值 ??? alert(box.style);????????????? //獲取style屬性對象 ??? alert(box.style.color);???? //獲取style屬性對象中的color屬性的值 ??? alert(box.className);?? //獲取class屬性的值??? };
注:直接調(diào)用的屬性也可以賦值
示例:
var box=document.getElementById('box'); box.id="KKK"; box.innerHTML="玩轉(zhuǎn)<strong>JS</strong>"; //賦值,可以解析HTML,不是單獨的文本(包含HTML標簽)。
2、getElementsByTagName()方法
getElementsByTagName()方法將返回一個對象數(shù)組HTMLCollection(NodeList),這個數(shù)組保存著所有相同元素名的節(jié)點列表。該方法需要一個參數(shù):HTML標簽的名稱。
document.getElementsByTagName('*');????????????? //獲取所有元素
注:IE瀏覽器在使用通配符的時候,會把文檔最開始的HTML的規(guī)范聲明當(dāng)作第一個元素。
示例:
window.onload=function(){ ???? var li=document.getElementsByTagName('li');??? //參數(shù)傳遞一個標簽名即可 ???? alert(li);???????????????????????????? //返回一個數(shù)組集合,HTMLCollection ???? alert(li.length);????????????????? //返回數(shù)組的個數(shù) ???? alert(li[0]);??????????????????????? //HTMLliElement,返回數(shù)組的第一個 ???? alert(li.item(0));??????????????? //返回數(shù)組的第一個 ???? alert(li[0].tagName);??????? //輸出第一個LI標簽 ???? alert(li[0].innerHTML);??? //輸出第一個<li>標簽的文本:即1 };
示例獲取body節(jié)點:
window.onload=function(){ ?? //獲取body節(jié)點對象 ?? var body=document.getElementsByName('body')[0]; ?? alert(body);??????????? //返回HTMLBodyElement對象,body節(jié)點 };
注:不管是getElementById還是getElementsByTagName,在傳遞參數(shù)的時候,并不是所有瀏覽器都必須區(qū)分大小寫,為了防止不必要的錯誤和麻煩,我們必須堅持養(yǎng)成區(qū)分大小寫的習(xí)慣。
3、getElementsByName()方法
getElementsByName()方法可以獲取相同名稱(name)的元素,返回一個對象數(shù)組HTMLCollection(NodeList)。該方法需要一個參數(shù):HTML標簽的name屬性的值。
示例:
<html xmlns="http://www.w3.org/1999/xhtml"> ?<head> ??<meta/> ??<title>DOM基礎(chǔ)</title>?? ?</head> ?<body> ??? <div? id="box" title="標題" class="pox" style="color:red">測試Div</div> ??? <input name="test" type="checkbox" value="測試" checked="checked"> ????????? <ul> ?????? <li>1</li> ??? <li>2</li> ??? <li>3</li> ??? </ul> ?</body> ?<script type="text/javascript" src="demo.js"></script> </html>
JS代碼:
window.onload=function(){ ????? var input=document.getElementsByName('test')[0]; ????? alert(input.value);????????????????????? //輸出:測試 ????? alert(input.checked);???????????????? //輸出:true };
注:對于并不是HTML合法的屬性,那么在JS獲取的兼容性上也會存在差異,IE瀏覽器支持本身合法的name屬性,而不合法的就會出現(xiàn)不兼容的問題。
4、getAttribute()方法
getAttribute()方法將獲取元素中某個屬性的值。它和直接使用屬性獲取屬性值的方法有一定區(qū)別。
示例:
window.onload=function(){ ?? var box=document.getElementById('box'); ?? alert(box.bbb);??????????????????????????? //自定義,W3C不合法,只有IE瀏覽器支持 ?? alert(box.getAttribute('style'));??? //非IE返回的是style字符串,IE返回的是對象,這里有個不兼容的問題 ?? alert(box.getAttribute('bbb'));???? //自定義,所有瀏覽器都兼容 };
注:HTML通用屬性style和onclick,IE7更低的版本style返回一個對象,onclick返回一個函數(shù)式。雖然IE8已經(jīng)修復(fù)了這個bug,但為了更好的兼容,開發(fā)人員只有盡可能避免使用getAttribute()訪問HTML屬性了,或者碰到特殊的屬性獲取做特殊的兼容處理。
5、setAttribute()方法
setAttribute()方法將設(shè)置元素中某個屬性和值。它需要接受兩個參數(shù):屬性名和值。如果屬性本身已存在,那么就會被覆蓋。
示例:
window.onload=function(){ ?? var box=document.getElementById('box'); ?? box.setAttribute('title','標題');???????????????????? //創(chuàng)建一個屬性和屬性值 ?? box.setAttribute('align','center');??????????????????? //設(shè)置居中 ?? box.setAttribute('bbb','ccc');?????????????????????? //設(shè)置自定義的屬性和值 };
注:在IE7及更低的版本中,使用setAttribute()方法設(shè)置class和style屬性是沒有效果的,雖然IE8解決了這個bug,但還是不建議使用。
6、removeAttribute()方法
removeAttribute()方法可以移除HTML屬性。
示例:
window.onload=function(){ ?? var box=document.getElementById('box'); ?? box.removeAttribute('style');??????? //移除屬性 };
注:IE6及更低版本不支持removeAttribute()方法。
到此這篇關(guān)于JavaScript操作DOM對象詳解的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript setTimeout和setInterval 的區(qū)別
window對象有兩個主要的定時方法,分別是setTimeout 和 setInteval 他們的語法基本上相同,但是完成的功能取有區(qū)別。2009-12-12微信公眾號開發(fā) 自定義菜單跳轉(zhuǎn)頁面并獲取用戶信息實例詳解
這篇文章主要介紹了微信公眾號開發(fā) 自定義菜單跳轉(zhuǎn)頁面并獲取用戶信息實例詳解的相關(guān)資料,需要的朋友可以參考下2016-12-12關(guān)于鍵盤事件中keyCode、which和charCode 的兼容性測試
關(guān)于鍵盤事件中keyCode、which和charCode 的兼容性測試...2006-12-12