javascript學習筆記(十八)獲得頁面中的元素

1.獲取元素
getElementById()方法,通過元素的id獲取元素,接受一個參數即要獲取元素的id,如果不存在這個id返回 null
註意不要讓表單元素的name和別的元素的id相同,IE8以下的IE瀏覽器用這個方法通過元素的name屬性可以獲得該元素
以下面元素為例
<p id ="myDiv">這裡是id為“myDiv”的p內容</p>
var document.getElementById("myDiv");        //"myDiv"區分大小寫,取得<p>元素的引用
getElementsByTagName()方法,通過元素的標簽名獲得元素,接受一個參數即要獲取元素的標簽名,返回包含0個或多個的NodeList
1 var images = document.getElementsByTagName("img");        //獲取頁面中的所有<img>元素
2
3 alert(images.length);         //圖像的數量
4 alert(images[0].src);         //第一個圖片元素的src
5 alert(images.item(0).src);    //同上
getElementsByName()方法,通過元素的name屬性獲得元素,接受一個參數即要獲取元素的name屬性,常用來獲取單選按鈕
1 <ul>
2     <li><input type="radio" name="color" value="red" id="colorRed"><label for="colorRed"></label></li>
3     <li><input type="radio" name="color" value="green" id="colorGreen"><label for="colorGreen"></label></li>
4     <li><input type="radio" name="color" value="blue" id="colorBlue"><label for="colorBlue"></label></li>
5 </ul>
var radios = document.getElementsByName("color");    //獲取name="color"的所有單選按鈕
 
2.獲取元素子節點或元素子節點及其後代節點
1 <ul id="myList">
2     <li>項目一</li>
3     <li>項目二</li>
4     <li>項目三</li>
5 </ul>
IE認為<ul>元素有3個子節點,分別是3個元素,其他瀏覽器會認為有7個子節點,包括3個元素和4個文本節點,如果<ul>在一行中:
<ul id="myList"><li>項目一</li><li>項目二</li><li>項目三</li></ul>  
任何瀏覽器都認為有3個子節點
獲取元素的子節點:
 
1 var ul = document.getElementById("myList");
2 for (var i=0,len = ul.childNodes.length ; i < len ; i++ ) {
3     if ( ul.childNodes.length[i].nodeType == 1) {            //nodeType == 1 說明節點是元素節點,而不是文本節點
4                 //執行某些操作
5     }
6 }
 
獲取元素的子節點及其後代節點:
1 var ul = document.getElementById("myList");
2 var items = ul.getElementsByTagName("li");        //li裡的li也會被取得

 

 

摘自 晴天漫步

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *