Javascript 验证单选(radio)值 和多选框

 

 

<script type="text/javascript">
// 说明: 用 Javascript 验证表单(form)中的单选(radio)值

 

 

 

function getRadioValue(radio)
{
if (!radio.length && radio.type.toLowerCase() == 'radio')
{ return (radio.checked)?radio.value:''; }
if (radio[0].tagName.toLowerCase() != 'input' ||
radio[0].type.toLowerCase() != 'radio')
{ return ''; }
var len = radio.length;
for(i=0; i<len; i++)
{
if (radio[i].checked)
{
return radio[i].value;
}
}
return '';
}
</script>

radio 和 checkbox 一样,都是 name 相同,值有多个,在获取 radio 值的时候,我们不能按照普通文本框 .value 的方式,而是要判断哪个被选中了。

当一组 radio 有多个选项时,我们可以通过循环,以 radio[i] 的方式判断某个选项是否被选中来返回值,但是当一组 radio 只有一个选项时,获取值的方式又有变化,代码中以 return (radio.checked)?radio.value:''; 这样的方式直接判断是否选中,然后返回对应值。


上面的代码传入的参数是 radio 对象,如:

 代码如下:

var radioTest = document.forms['testForm'].elements['radioTest'];
if (getRadioValue(radioTest) == '')
{ ...... }


根据判断结果执行你想要的操作。

 

 

和单选框一样,在用 Javascript 验证表单(form)中多选框(checkbox)的值时,都会遇到问题,原因是 checkbox 和普通的文本框在获取值的时候有很大不同,本文介绍了一个较为通用的获取 checkbox 值的方法。

Javascript:

 
  1.  
  2. <script type= "text/javascript">
  3.  
  4. // 说明: 用 Javascript 验证表单(form)中多选框(checkbox)的值
  5.  
  6.  
  1. function getCheckboxValue (checkbox )
  2. {
  3. if (!checkbox. length && checkbox. type. toLowerCase ( ) == 'checkbox' )
  4. { return (checkbox. checked )?checkbox. value: ''; }
  5. if (checkbox [ 0 ]. tagName. toLowerCase ( ) != 'input' ||
  6. checkbox [ 0 ]. type. toLowerCase ( ) != 'checkbox' )
  7. { return ''; }
  8.  
  9. var val = [ ];
  10. var len = checkbox. length;
  11. for (i= 0; i<len; i++ )
  12. {
  13. if (checkbox [i ]. checked )
  14. {
  15. val [val. length ] = checkbox [i ]. value;
  16. }
  17. }
  18. return (val. length )?val: '';
  19. }
  20.  
  21. </script>

  22. 和 radio 一样,都是 name 相同,值有多个,在获取 checkbox 值的时候,我们不能按照普通文本框 .value 的方式,而是要判断哪个被选中了。

    当一组 checkbox 有多个选项时,我们可以通过循环,以 checkbox[i] 的方式判断某个选项是否被选中来返回值,但是当一组 checkbox 只有一个选项时,获取值的方式又有变化,代码中以 (checkbox.checked)?checkbox.value:''; 的方式直接判断是否选中,然后返回对应值。

    上面的代码传入的参数是 checkbox 对象,如: 

    var checkboxTest document.forms['testForm'].elements['checkboxTest'];
    if (getCheckboxValue(checkboxTest) == '')
    ...... }

    根据判断结果执行你想要的操作。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值