document.getElementsByName 和 document.getElementsByTagName

  • 当页面上的控件同名且多个的时候,从程序的严密角度出发,需要判断长度,而且有长度和没长度是两种引用方法.
    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对象)
    <div id=radiodiv language=javascript >
    <INPUT name=radio1 value=1 type="radio">
    <INPUT name=radio1 value=0 type="radio" CHECKED>
    </div>

    document.getElementsByName("radio1").item(0).value 结果是 1

    但是.相对应的,还有另一个方法,可以应用的对象会更广一点:

    getElementsByTagName

    <div id=radiodiv language=javascript >
    <INPUT name=radio1 value=1 type="radio" id=myRadio1>
    <INPUT name=radio1 value=0 type="radio" id=myRadio2 CHECKED >
    </div>

    radiodiv.getElementsByTagName("input").item(0).value 结果是 1

    ,比如我知道了一个<DIV ID='aaa'><input name=input1 value=1 type=radio ><input name=input1 value=2 type=radio>......</DIV>我要取DIV里面的所有input,这样写就可以了:

    aaa.getElementsByTagName('INPUT')

    这样就有效的可以和别的DIV(比如说有个叫bbb的DIV,里面的也是一样的input)相区别.

    同getElementsByTagName相对应,

    还有一个document.body.all.tags()

    能用这个方法的对象比getElementsByTagName要小得多.但比getElementsByName要多.


    到这里我们还要提一下getElementById

    它也是只有document对象才能使用,而且返回的是数组的第一个元素,呵呵,它的方法名都写明了是getElement而不是getElements

    <div id=radiodiv language=javascript >
    <INPUT name=radio1 value=1 type="radio" id=myRadio1 >
    <INPUT name=radio1 value=0 type="radio" id=myRadio2 value="myVal2" CHECKED >
    </div>

    document.getElementById("myRadio2").value 结果是 myVal2  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

1598583

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值