javascript學(xué)習(xí)筆記(十八) 獲得頁(yè)面中的元素代碼
更新時(shí)間:2012年06月20日 20:20:36 作者:
javascript學(xué)習(xí)筆記之獲得頁(yè)面中的元素代碼,需要的朋友可以參考下
1.獲取元素
getElementById()方法,通過(guò)元素的id獲取元素,接受一個(gè)參數(shù)即要獲取元素的id,如果不存在這個(gè)id返回 null
注意不要讓表單元素的name和別的元素的id相同,IE8以下的IE瀏覽器用這個(gè)方法通過(guò)元素的name屬性可以獲得該元素
以下面元素為例
<div id ="myDiv">這里是id為“myDiv”的div內(nèi)容</div>var document.getElementById("myDiv"); //"myDiv"區(qū)分大小寫(xiě),取得<div>元素的引用
getElementsByTagName()方法,通過(guò)元素的標(biāo)簽名獲得元素,接受一個(gè)參數(shù)即要獲取元素的標(biāo)簽名,返回包含0個(gè)或多個(gè)的NodeList
var images = document.getElementsByTagName("img"); //獲取頁(yè)面中的所有<img>元素
alert(images.length); //圖像的數(shù)量
alert(images[0].src); //第一個(gè)圖片元素的src
alert(images.item(0).src); //同上
getElementsByName()方法,通過(guò)元素的name屬性獲得元素,接受一個(gè)參數(shù)即要獲取元素的name屬性,常用來(lái)獲取單選按鈕
<ul>
<li><input type="radio" name="color" value="red" id="colorRed"><label for="colorRed"></label></li>
<li><input type="radio" name="color" value="green" id="colorGreen"><label for="colorGreen"></label></li>
<li><input type="radio" name="color" value="blue" id="colorBlue"><label for="colorBlue"></label></li>
</ul>var radios = document.getElementsByName("color"); //獲取name="color"的所有單選按鈕
2.獲取元素子節(jié)點(diǎn)或元素子節(jié)點(diǎn)及其后代節(jié)點(diǎn)
<ul id="myList">
<li>項(xiàng)目一</li>
<li>項(xiàng)目二</li>
<li>項(xiàng)目三</li>
</ul>
注意:IE認(rèn)為<ul>元素有3個(gè)子節(jié)點(diǎn),分別是3個(gè)元素,其他瀏覽器會(huì)認(rèn)為有7個(gè)子節(jié)點(diǎn),包括3個(gè)元素和4個(gè)文本節(jié)點(diǎn),如果<ul>在一行中:
<ul id="myList"><li>項(xiàng)目一</li><li>項(xiàng)目二</li><li>項(xiàng)目三</li></ul>
任何瀏覽器都認(rèn)為有3個(gè)子節(jié)點(diǎn)
獲取元素的子節(jié)點(diǎn):
var ul = document.getElementById("myList");
for (var i=0,len = ul.childNodes.length ; i < len ; i++ ) {
if ( ul.childNodes.length[i].nodeType == 1) { //nodeType == 1 說(shuō)明節(jié)點(diǎn)是元素節(jié)點(diǎn),而不是文本節(jié)點(diǎn)
//執(zhí)行某些操作
}
}
獲取元素的子節(jié)點(diǎn)及其后代節(jié)點(diǎn):
var ul = document.getElementById("myList");
var items = ul.getElementsByTagName("li"); //li里的li也會(huì)被取得
3通過(guò)節(jié)點(diǎn)的屬性查找其它節(jié)點(diǎn)
nextSibling屬性指向當(dāng)前節(jié)點(diǎn)的下一個(gè)兄弟節(jié)點(diǎn)
previousSibling屬性指向當(dāng)前節(jié)點(diǎn)的上一個(gè)兄弟節(jié)點(diǎn)
firstChild屬性指向第一個(gè)子節(jié)點(diǎn),lastChild指向最后一個(gè)子節(jié)點(diǎn)
childNodes保存著所有子節(jié)點(diǎn)(其實(shí)是NodeList對(duì)象),可以通過(guò)方括號(hào)的方法訪問(wèn)如 someNode.childNodes[0] 訪問(wèn)第一個(gè)子節(jié)點(diǎn)
parentNode屬性指向父節(jié)點(diǎn)
節(jié)點(diǎn)關(guān)系如下:
function converToArray (nodes) {
var arrary = null;
try {
array = Array.prototype.slice.call(nodes,0);
}
catch (ex) {
array = new Array();
for (var i=0,len=nodes.length ; i<len ; i++) {
array.push(nodes[i]);
}
}
return array;
}
var div = document.getElementById("side");
alert(converToArray(div.childNodes));
getElementById()方法,通過(guò)元素的id獲取元素,接受一個(gè)參數(shù)即要獲取元素的id,如果不存在這個(gè)id返回 null
注意不要讓表單元素的name和別的元素的id相同,IE8以下的IE瀏覽器用這個(gè)方法通過(guò)元素的name屬性可以獲得該元素
以下面元素為例
<div id ="myDiv">這里是id為“myDiv”的div內(nèi)容</div>var document.getElementById("myDiv"); //"myDiv"區(qū)分大小寫(xiě),取得<div>元素的引用
getElementsByTagName()方法,通過(guò)元素的標(biāo)簽名獲得元素,接受一個(gè)參數(shù)即要獲取元素的標(biāo)簽名,返回包含0個(gè)或多個(gè)的NodeList
復(fù)制代碼 代碼如下:
var images = document.getElementsByTagName("img"); //獲取頁(yè)面中的所有<img>元素
alert(images.length); //圖像的數(shù)量
alert(images[0].src); //第一個(gè)圖片元素的src
alert(images.item(0).src); //同上
getElementsByName()方法,通過(guò)元素的name屬性獲得元素,接受一個(gè)參數(shù)即要獲取元素的name屬性,常用來(lái)獲取單選按鈕
復(fù)制代碼 代碼如下:
<ul>
<li><input type="radio" name="color" value="red" id="colorRed"><label for="colorRed"></label></li>
<li><input type="radio" name="color" value="green" id="colorGreen"><label for="colorGreen"></label></li>
<li><input type="radio" name="color" value="blue" id="colorBlue"><label for="colorBlue"></label></li>
</ul>var radios = document.getElementsByName("color"); //獲取name="color"的所有單選按鈕
2.獲取元素子節(jié)點(diǎn)或元素子節(jié)點(diǎn)及其后代節(jié)點(diǎn)
復(fù)制代碼 代碼如下:
<ul id="myList">
<li>項(xiàng)目一</li>
<li>項(xiàng)目二</li>
<li>項(xiàng)目三</li>
</ul>
注意:IE認(rèn)為<ul>元素有3個(gè)子節(jié)點(diǎn),分別是3個(gè)元素,其他瀏覽器會(huì)認(rèn)為有7個(gè)子節(jié)點(diǎn),包括3個(gè)元素和4個(gè)文本節(jié)點(diǎn),如果<ul>在一行中:
<ul id="myList"><li>項(xiàng)目一</li><li>項(xiàng)目二</li><li>項(xiàng)目三</li></ul>
任何瀏覽器都認(rèn)為有3個(gè)子節(jié)點(diǎn)
獲取元素的子節(jié)點(diǎn):
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList");
for (var i=0,len = ul.childNodes.length ; i < len ; i++ ) {
if ( ul.childNodes.length[i].nodeType == 1) { //nodeType == 1 說(shuō)明節(jié)點(diǎn)是元素節(jié)點(diǎn),而不是文本節(jié)點(diǎn)
//執(zhí)行某些操作
}
}
獲取元素的子節(jié)點(diǎn)及其后代節(jié)點(diǎn):
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList");
var items = ul.getElementsByTagName("li"); //li里的li也會(huì)被取得
3通過(guò)節(jié)點(diǎn)的屬性查找其它節(jié)點(diǎn)
nextSibling屬性指向當(dāng)前節(jié)點(diǎn)的下一個(gè)兄弟節(jié)點(diǎn)
previousSibling屬性指向當(dāng)前節(jié)點(diǎn)的上一個(gè)兄弟節(jié)點(diǎn)
firstChild屬性指向第一個(gè)子節(jié)點(diǎn),lastChild指向最后一個(gè)子節(jié)點(diǎn)
childNodes保存著所有子節(jié)點(diǎn)(其實(shí)是NodeList對(duì)象),可以通過(guò)方括號(hào)的方法訪問(wèn)如 someNode.childNodes[0] 訪問(wèn)第一個(gè)子節(jié)點(diǎn)
parentNode屬性指向父節(jié)點(diǎn)
節(jié)點(diǎn)關(guān)系如下:

復(fù)制代碼 代碼如下:
function converToArray (nodes) {
var arrary = null;
try {
array = Array.prototype.slice.call(nodes,0);
}
catch (ex) {
array = new Array();
for (var i=0,len=nodes.length ; i<len ; i++) {
array.push(nodes[i]);
}
}
return array;
}
var div = document.getElementById("side");
alert(converToArray(div.childNodes));
您可能感興趣的文章:
- javascript學(xué)習(xí)筆記(十九) 節(jié)點(diǎn)的操作實(shí)現(xiàn)代碼
- javascript學(xué)習(xí)筆記(十七) 檢測(cè)瀏覽器插件代碼
- javascript學(xué)習(xí)筆記(十六) 系統(tǒng)對(duì)話框(alert、confirm、prompt)
- javascript學(xué)習(xí)筆記(十五) js間歇調(diào)用和超時(shí)調(diào)用
- javascript學(xué)習(xí)筆記(十四) window對(duì)象使用介紹
- javascript學(xué)習(xí)筆記(十三) js閉包介紹(轉(zhuǎn))
- javascript學(xué)習(xí)筆記(十二) RegExp類(lèi)型介紹
- javascript學(xué)習(xí)筆記(十一) 正則表達(dá)式介紹
- javascript學(xué)習(xí)筆記(十) js對(duì)象 繼承
- javascript學(xué)習(xí)筆記(九) js對(duì)象 設(shè)計(jì)模式
- javascript學(xué)習(xí)筆記(八) js內(nèi)置對(duì)象
- javascript學(xué)習(xí)筆記(七) js函數(shù)介紹
- javascript學(xué)習(xí)筆記(六) Date 日期類(lèi)型
- javascript學(xué)習(xí)筆記(五) Array 數(shù)組類(lèi)型介紹
- javascript學(xué)習(xí)筆記(四) Number 數(shù)字類(lèi)型
- javascript學(xué)習(xí)筆記(三) String 字符串類(lèi)型介紹
- javascript學(xué)習(xí)筆記(二) js一些基本概念
- javascript學(xué)習(xí)筆記(一) 在html中使用javascript
- javascript學(xué)習(xí)筆記(二十) 獲得和設(shè)置元素的特性(屬性)
相關(guān)文章
Javascript學(xué)習(xí)筆記7 原型鏈的原理
說(shuō)到prototype,就不得不先說(shuō)下new的過(guò)程。2010-01-01
Javascript學(xué)習(xí)筆記之 函數(shù)篇(三) : 閉包和引用
本系列好久沒(méi)更新了,今天重新拿過(guò)來(lái),繼續(xù)前面未完成的事項(xiàng),本文我們就來(lái)談?wù)凧avascript 中一個(gè)最重要的特性--閉包的使用引用。2014-11-11
JavaScript操作HTML DOM節(jié)點(diǎn)的基礎(chǔ)教程
這篇文章主要介紹了JavaScript操作HTML DOM節(jié)點(diǎn)的基礎(chǔ)入門(mén)教程,包括對(duì)節(jié)點(diǎn)的創(chuàng)建修改刪除等操作,還特別提到了其中appendChild()與insertBefore()插入節(jié)點(diǎn)時(shí)需注意的問(wèn)題,需要的朋友可以參考下2016-03-03
javascript設(shè)計(jì)模式之對(duì)象工廠函數(shù)與構(gòu)造函數(shù)詳解
這篇文章主要介紹了javascript設(shè)計(jì)模式之對(duì)象工廠函數(shù)與構(gòu)造函數(shù)詳解,使用對(duì)象字面量,或者向空對(duì)象中動(dòng)態(tài)地添加新成員,是最簡(jiǎn)單易用的對(duì)象創(chuàng)建方法,除了這兩種常用的對(duì)象創(chuàng)建方式,JavaScript還提供了其他方法創(chuàng)建對(duì)象,需要的朋友可以參考下2015-07-07

