getElementByID,getElementsByName,getElementsByTagName的区别

原创 2008年10月02日 21:19:00

    WEB标准下可以通过getElementById(), getElementsByName(),getElementsByTagName()访问DOCUMENT中的任一个标签:<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

1getElementById()

通过ID来访问DOCUMENT中的某一特定元素。

例如有一个DIVIDdocid

<div id="docid"></div>

那么就可以用getElementById("docid")来获得这个元素。

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

     <title>ById</title>

     <style type="text/css">

         <!--

         #docid{

         height:400px;

         width:400px;

         background-color:#999;}

         -->

     </style>

</head>

<body><div id="docid" name="docname" onClick="bgcolor()"></div>

</body>

</html>

<script language="JavaScript" type="text/JavaScript">

     <!--

     function bgcolor(){

     document.getElementById("docid").style.backgroundColor="#000"

     }

     -->

</script>

 

2getElementsByName()

通过NAME来获得元素,复数ELEMENTS代表获得的不是一个元素,因为DOCUMENT中每一个元素的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

 

3getElementsByTagName()

通过TAGNAME(标签名称)来获得元素,一个DOCUMENT中当然会有相同的标签,所以这个方法也是取得一个数组。

下面这个例子有两个DIV,可以用getElementsByTagName("div")来访问它们,用getElementsByTagName("div")[0]访问第一个DIV,用

getElementsByTagName("div")[1]访问第二个DIV

<html>

<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;

         background-color:#999;}

         -->

     </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>

querySelector和getElementById性能分析与使用选择

记得我们在jquery里面得到一个元素要比直接使用javascript中的document.getElementById()等方法好用多了。随着现在浏览器的发展,目前几乎主流浏览器均支持了他们。包括 ...
  • hualimeme
  • hualimeme
  • 2015年03月18日 15:22
  • 7897

用#id取得的jQuery对象与document.getElementByIdid所得到的DOM对象区别

转载于: 贤心博客 用#id作为选择符取得的是jQuery对象而并非是document.getElementById(’id’)所得到的DOM对象,两者并不等价。 var $cr=$('#...
  • a1943206465
  • a1943206465
  • 2017年02月06日 15:02
  • 2474

js浏览器兼容问题总结及解决办法

javascript部分 1. document.form.item 问题 问题: 代码中存在 document.formName.item("itemName") 这样的语句,不能在FF下...
  • comeonJ
  • comeonJ
  • 2014年02月19日 10:44
  • 8671

getElementByID() getElementsByName() getElementsByTagName()的区别

getElementByID() getElementsByName() getElementsByTagName_r()的区别 Web标准下可以通过getElementById(), ge...
  • QTFYING
  • QTFYING
  • 2016年06月01日 14:44
  • 353

getElementById,getElementsByName,getElementsByTagName,getElementsByClassName四者之间的区别

在《Javascript DOM 编程艺术》与 W3school 中是这样定义的: getElementById():这个方法将返回一个与那个有着给定id属性值的元素节点对应的对象。 下面这个案例...
  • tashanhongye
  • tashanhongye
  • 2017年05月28日 20:05
  • 770

javascript getElementByID,getElementsByName,getElementsByTagName的区别

getElementByID,getElementsByName,getElementsByTagName区别注意:方法区分大小写!以人来举例说明,人有能标识身份的身份证,有姓名,有类别(大人、小孩、...
  • baidu_32731497
  • baidu_32731497
  • 2016年06月30日 22:37
  • 3640

getElementByID getElementsByName getElementsByTagName的区别和总结 +js+Mxl+xmlhttp

WEB标准下可以通过getElementById(), getElementsByName(), and getElementsByTagName()访问DOCUMENT中的任一个标签:1、getEl...
  • davidxj
  • davidxj
  • 2011年07月11日 14:07
  • 743

getElementByID和getElementsByName和getElementsByTagName和document.all的区别

document.all与document.getElementsByName区别 当页面上的控件同名且多个的时候,从程序的严密角度出发,需要判断长度,而且有长度和没长度是两种引用方法. oEle...
  • msg_java2011
  • msg_java2011
  • 2012年01月13日 15:34
  • 640

document.getElementsByName()与 document.getElementById()、document.getElementsByTagName()的区别

document.getElementsByName() 是根据控件名称获取这个控件对象,因为控件名称可以相同,返回的是一个对象数组。 document.getElementById() ...
  • sabic
  • sabic
  • 2011年12月05日 09:03
  • 1969

getElementByID getElementsByName getElementsByTagName用法详解

WEB标准下可以通过getElementById(), getElementsByName(), and getElementsByTagName()访问DOCUMENT中的任一个标签: 1、getE...
  • fox123871
  • fox123871
  • 2011年07月18日 16:33
  • 2545
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:getElementByID,getElementsByName,getElementsByTagName的区别
举报原因:
原因补充:

(最多只允许输入30个字)