2024年6月7日发(作者:)
javascript 入门 (3)getElementByName, getElementById等
用法
getElementByName不存在
只有getElement__S__ByName 和 getElementById
byId的时候,会根据html元素的id属性,根据规范id应当是唯一的,用来标示一
个element,比如
也可以用
mentByIdx("abc")来获取
而byName,从名字上看,就可以知道,它返回的是复数个对象。它根据name属性
(name可以重复),得到所有name属性与参数相同的控件组成的数组,不存在时,返回
0长度数组(.length == 0,而不是null)
比如
var array = mentsByName("abc");
if ( == 0) {
alert("Error");
return;
}
for (var i = 0; i < ; i++) {
alert(array[i].value);
}
当页面上的控件同名且多个的时候,你首先做的是什么?判断长度?的确,从程序的严密
角度出发,我们是需要判断长度,而且有长度和没长度是两种引用方法.我们来看:
oEle= ;//这里有一个aaa的对象,但我们不知道它现在长度是多少,
所以没办法对它操作.因此,我们要先做判断长度的过程.如下:
if(){}else{};
在两种情况下,花括号里面的内容写法也是不一样的:
if(){
for(var i = 0 ;i<;i++){
oEle[i].
}
}
else{
........
};
但是这样写是不是太复杂了点?而且当花括号里面的代码比较多的时候,我们要写两遍
代码,晕了先~
还好有mentsByName()这个方法.它对一个和多个的处理是一样的,
我们可以用:
oEle = mentsByName('aaa')来引用
当oEle只有1个的时候,那么就是oEle[0],有多个的时候,用下标法oEle[i]循环获取,
是不是很简单?
值得一提的是它对Name和ID的同样有效的.
但是它只能应用到document对象.相对应的,还有另一个方法,可以应用的对象会更广
一点:
getElementsByTagName,比如我知道了一个
ID='aaa'>......
我要取DIV里面的所有input,这样写就可以
了:mentsByTagName_r('INPUT'),这样就有效的可以和别的DIV(比如说有个
叫bbb的DIV,里面的也是一样的input)相区别.
同getElementsByTagName相对应,还有一个(),能用这个
方法的对象比getElementsByTagName要小得多.但比getElementsByName要多.
到这里我们还要提一下getElementById,它也是只有document对象才能使用,而且
返回的是数组的第一个元素,呵呵,它的方法名都写明了是getElement而不是
getElements,所以,千万不要搞浑了
发布评论