`
angeldhp
  • 浏览: 59320 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

document.all还是document.getElementsByName?

 
阅读更多
当页面上的控件同名且多个的时候,你首先做的是什么?判断长度?的确,从程序的严密角度出发,我们是需要判断长度,而且有长度和没长度是两种引用方法.我们来看:
oEle= document.all.aaa ;//这里有一个aaa的对象,但我们不知道它现在长度是多少,所以没办法对它操作.因此,我们要先做判断长度的过程.如下:
if(oEle.length){}else{};
在两种情况下,花括号里面的内容写法也是不一样的:
if(oEle.length){
   for(var i = 0 ;i<oEle.length;i++){
      oEle[i].value........
  }
}
else{
     oEle.value........
};

但是这样写是不是太复杂了点?而且当花括号里面的代码比较多的时候,我们要写两遍代码,晕了先~
还好有document.getElementsByName()这个方法.它对一个和多个的处理是一样的,我们可以用:
oEle = document.getElementsByName('aaa')来引用
当oEle只有1个的时候,那么就是oEle[0],有多个的时候,用下标法oEle[i]循环获取,是不是很简单?

值得一提的是它对Name和ID的同样有效的.
但是它只能应用到document对象.相对应的,还有另一个方法,可以应用的对象会更广一点:
getElementsByTagName,比如我知道了一个<DIV ID='aaa'><input/><input/>......</DIV>
我要取DIV里面的所有input,这样写就可以了:aaa.getElementsByTagName('INPUT'),这样就有效的可以和别的DIV(比如说有个叫bbb的DIV,里面的也是一样的input)相区别.
同getElementsByTagName相对应,还有一个document.body.all.tags(),能用这个方法的对象比getElementsByTagName要小得多.但比getElementsByName要多.
到这里我们还要提一下getElementById,它也是只有document对象才能使用,而且返回的是数组的第一个元素,呵呵,它的方法名都写明了是getElement而不是getElements,所以,千万不要搞浑了.
分享到:
评论

相关推荐

    JS:document.all的用法

    然而,需要注意的是,`document.all`在标准浏览器中可能不受支持,因此在实际项目中,更推荐使用`document.getElementById`、`document.getElementsByName`等标准方法来访问DOM元素,以确保代码的兼容性和可维护性。

    document.all与getElementById、getElementsByName、getElementsByTagName用法区别-document.all第1/2页

    本文将深入探讨`document.all`与`getElementById`、`getElementsByName`、`getElementsByTagName`这四个方法的区别和用法。 1. `document.all` `document.all` 是一个数组集合,它包含了HTML文档中所有的元素,...

    document.all与WEB标准

    - `document.getElementsByName`: 获取具有相同NAME属性的所有元素。 - `document.getElementsByTagName`: 获取具有相同标签名的所有元素。 - `querySelector`和`querySelectorAll`: 提供更强大的选择器功能,类似于...

    document.all与getElementById、getElementsByName、getElementsByTagName用法区别-getElementById

    在HTML文档对象模型(DOM)中,有三种主要方法用于查找HTML元素:`document.all`,`getElementById()`,`getElementsByName()` 和 `getElementsByTagName()`。这些方法各有其特性和适用场景,理解它们的区别对于编写...

    Document和Document.all区别分析

    如果不在表单内,`inputName` 可能能直接引用,否则就要借助 `document.getElementById` 或 `document.getElementsByName`。 此外,对于具有ID的元素,如 `&lt;div id="aa"&gt;`,我们通常使用 `document.getElementById...

    JS的document.all函数使用示例

    例如,使用`document.getElementById`替代`document.all`,`document.getElementsByName`替代`document.all`对name属性的访问。 五、更安全的`document.all`使用示例 在复杂或可能有重复ID的情况下,可以采用以下...

    解决 firefox 不支持 document.all的方法

    解决 Firefox 不支持 document.all 的方法 在 Web 开发中,我们经常会遇到浏览器的兼容性问题,其中一个常见的问题就是 Firefox 不支持 document.all 对象。document.all 是一个遗留的对象,早期的 IE 浏览器支持它...

    java代码大全

    后面还有很多很多代码…… ...document.getElementsByName("r1"); document.getElementById(id); • 定时 timer=setInterval(‘scrollwindow()‘,delay); clearInterval(timer); 后面还有很多很多……

    DOCUMENT的对象操作

    - `document.getElementsByName(Name)`: 根据Name属性找到所有相关元素的集合。 - `document.body.appendChild(oTag)`: 将一个元素添加到body元素的末尾,实现动态添加HTML元素。 3. **集合与对象**: - `all`: ...

    JavaScript中document.forms[0]与getElementByName区别

    总结来说,document.forms[0]和document.getElementsByName('usernames')虽然在某些情况下可以达到相同的效果,但它们在返回值类型、适用场景以及对id和name属性的处理上存在本质的区别。理解这些区别有助于在实际...

    Javascript小技巧一箩筐

    - `document.getElementsByName("r1")`:通过name属性获取一组元素。 - `document.getElementById(id)`:通过id获取特定元素。 - `document.createElement("SPAN")`:创建新的元素节点。 - `obj.scrollIntoView...

    常用javascript

    document.getElementsByName()和document.getElementById()是常用的DOM元素查找方法。定时器可以通过setInterval()和clearInterval()来设置和清除。 JavaScript提供了编码和解码的方法,如escape()和unescape()。...

    Javascript技巧很全.doc

    12. **查找对象**:`document.getElementsByName`和`document.getElementById`分别通过名称和ID查找元素。 13. **对象事件解绑**:`detachEvent`用于取消事件绑定,如`document.all.xxx.detachEvent("onclick", a);...

    js常用代码

    * 查找对象:`document.getElementsByName("r1")`和`document.getElementById(id)` *父对象:`obj.parentElement(dhtml)`和`obj.parentNode(dom)` 其他 * 定时器:`timer=setInterval('scrollwindow()',delay)`和`...

Global site tag (gtag.js) - Google Analytics