js验证表单(form)中多选框(checkbox)值
作者:CodeBit.cn 来源:CodeBit.cn 时间:2008-03-18 13:39:00
和单选框一样,许多新手在用 Javascript 验证表单(form)中多选框(checkbox)的值时,都会遇到问题,原因是 checkbox 和普通的文本框在获取值的时候有很大不同,本文介绍了一个较为通用的获取 checkbox 值的方法,希望对新手有用。
<script type="text/javascript">
// 说明: 用 Javascript 验证表单(form)中多选框(checkbox)的值
// 作者: CodeBit.cn ( http://www.CodeBit.cn )
function getCheckboxValue(checkbox) {
if (!checkbox.length && checkbox.type.toLowerCase() == 'checkbox')
{ return (checkbox.checked)?checkbox.value:''; }
if (checkbox[0].tagName.toLowerCase() != 'input' || checkbox[0].type.toLowerCase() != 'checkbox')
{ return ''; }
var val = [];
var len = checkbox.length;
for(i=0; i<len; i++)
{
if (checkbox[i].checked)
{
val[val.length] = checkbox[i].value;
}
}
return (val.length)?val:'';
}
</script>
和 radio 一样,都是 name 相同,值有多个,在获取 checkbox 值的时候,我们不能按照普通文本框 .value 的方式,而是要判断哪个被选中了。
当一组 checkbox 有多个选项时,我们可以通过循环,以 checkbox[i] 的方式判断某个选项是否被选中来返回值,但是当一组 checkbox 只有一个选项时,获取值的方式又有变化,代码中以 (checkbox.checked)?checkbox.value:''; 的方式直接判断是否选中,然后返回对应值。
上面的代码传入的参数是 checkbox 对象,如:
var checkboxTest = document.forms['testForm'].elements['checkboxTest'];
if (getCheckboxValue(checkboxTest) == '')
{ ...... }
根据判断结果执行你想要的操作。
代码演示:
标签:多选框,checkbox,javascript,表单,form
0
投稿
猜你喜欢
显示/隐藏引出的CSS Bug
2010-10-20 20:13:00
写给JavaScript库开发者们的规则
2008-10-26 12:30:00
服务器XMLHTTP(Server XMLHTTP in ASP)基础知识
2011-03-06 11:11:00
避免使用滤镜
2009-10-13 20:30:00
一段ASP的HTTP_REFERER判断代码
2011-03-25 10:41:00
如何对Oracle8数据库进行维护?
2009-11-20 18:01:00
setInterval 和 setTimeout 会产生内存溢出
2008-03-08 13:10:00
网页对联广告代码效果大全
2007-10-25 23:16:00
vbscript与javascript如何传递变量(包括服务器端与客户端)
2008-04-09 13:46:00
微软建议的ASP性能优化28条守则(6)
2008-02-29 11:43:00
FireScope-面向Web开发者和设计者的参考手册
2009-03-22 15:35:00
用JS访问操作iframe框架里的dom
2008-11-10 13:05:00
MySQL 通过索引优化含ORDER BY的语句
2010-03-25 10:28:00
区分有单选框的选项和普通的选项
2008-04-17 13:44:00
高效的删除HTML标签的函数
2009-02-26 13:02:00
SQL Server中处理空值时涉及的三问题
2009-01-20 11:24:00
[翻译]标记语言和样式手册 Chapter 9 精简标签
2008-02-01 09:55:00
用JS找出字符串中出现次数最多的字母
2007-11-12 13:40:00
也谈用户体验
2009-07-15 12:56:00
解析SQL Server 2005 溢用之:合并列值
2009-01-23 14:08:00