JS中獲取元素使用getElementByID()、getElementsByName()、getElementsByTagName()的用法和區別


Web標准下可以通過getElementById(), getElementsByName(), and getElementsByTagName()訪問Documnent中的任一個標簽:
 
1 getElementById(“ID”)
getElementById()可以訪問Documnent中的某一特定元素,顧名思義,就是通過ID來取得元素,所以只能訪問設置了ID的元素。
比如說有一個DIV的ID為docid:
<div id="docid"></div>

 

那么就可以用getElementById("docid")來獲得這個元素。


2  getElementsByName(“Name”)
這個是通過name來獲得元素,但不知大家注意沒有,這個是get elemnets,復數elemnets代表獲得的不是一個元素,為什么呢?
因為Documnent中每一個元素的ID是唯一的,但NAME卻可以重復。打個比喻就像人的身份證號是唯一的(理論上,雖然現實中有重復),但名字重復的卻很多。如果一個文檔中有兩個以上的標簽NAME相同,那么getElementsByName()就可以取得這些元素組成一個數組。
 
比如有兩個DIV:
<div name="docname" id="docid1"></div>
<div name="docname" id="docid2"></div>

 

那么可以用getElementsByName("docname")獲得這兩個DIV,用getElementsByName("docname")[0]訪問第一個DIV,用getElementsByName("docname")[1]訪問第二個DIV。
 
 
3 getElementsByTagName(“TagName”)
這是通過TagName(標簽名稱)來獲得元素,一個Document中當然會有相同的標簽,所以這個方法也是取得一個數組。
下面這個例子有兩個DIV,可以用getElementsByTagName("div")來訪問它們,用getElementsByTagName("div")[0]訪問第一個DIV,,用getElementsByTagName("div")[1]訪問第二個DIV。
 
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>Byname,tag</title>
<style type="text/css">
<!--
    #docid1,#docid2{
    margin:10px;
    height:400px;
    width:400px;
    }
-->
</style>
</head>
<body>
<div name="docname" id="docid1" onClick="bgcolor()"></div>
<div name="docname" id="docid2" onClick="bgcolor()"></div>
</body>
</html>
<script language="JavaScript" type="text/JavaScript">
<!--
function bgcolor(){
    var docnObj=document.getElementsByTagName("div");
    docnObj[0].style.backgroundColor = "black";
    docnObj[1].style.backgroundColor = "black";
}
-->
</script>
總結:
總結一下標准DOM,訪問某一特定元素盡量用標准的getElementById(),訪問標簽用標准的getElementByTagName(),但IE不支持getElementsByName(),所以就要避免使用getElementsByName(),但getElementsByName()和不符合標准的document.all[]也不是全無是處,它們有自己的方便之處,用不用那就看網站的用戶使用什么瀏覽器,由你自己決定了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM