用 Javascript 驗(yàn)證表單(form)中多選框(checkbox)值
更新時(shí)間:2009年09月08日 20:46:08 作者:
和單選框一樣,許多新手在用 Javascript 驗(yàn)證表單(form)中多選框(checkbox)的值時(shí),都會(huì)遇到問(wèn)題,原因是 checkbox 和普通的文本框在獲取值的時(shí)候有很大不同
本文介紹了一個(gè)較為通用的獲取 checkbox 值的方法,希望對(duì)新手有用。
<script type="text/javascript">
// 說(shuō)明: 用 Javascript 驗(yàn)證表單(form)中多選框(checkbox)的值
// 作者: CodeBit
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 相同,值有多個(gè),在獲取 checkbox 值的時(shí)候,我們不能按照普通文本框 .value 的方式,而是要判斷哪個(gè)被選中了。
當(dāng)一組 checkbox 有多個(gè)選項(xiàng)時(shí),我們可以通過(guò)循環(huán),以 checkbox[i] 的方式判斷某個(gè)選項(xiàng)是否被選中來(lái)返回值,但是當(dāng)一組 checkbox 只有一個(gè)選項(xiàng)時(shí),獲取值的方式又有變化,代碼中以 (checkbox.checked)?checkbox.value:''; 的方式直接判斷是否選中,然后返回對(duì)應(yīng)值。
上面的代碼傳入的參數(shù)是 checkbox 對(duì)象,如:
var checkboxTest = document.forms['testForm'].elements['checkboxTest'];
if (getCheckboxValue(checkboxTest) == '')
{ ...... }
根據(jù)判斷結(jié)果執(zhí)行你想要的操作。
復(fù)制代碼 代碼如下:
<script type="text/javascript">
// 說(shuō)明: 用 Javascript 驗(yàn)證表單(form)中多選框(checkbox)的值
// 作者: CodeBit
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 相同,值有多個(gè),在獲取 checkbox 值的時(shí)候,我們不能按照普通文本框 .value 的方式,而是要判斷哪個(gè)被選中了。
當(dāng)一組 checkbox 有多個(gè)選項(xiàng)時(shí),我們可以通過(guò)循環(huán),以 checkbox[i] 的方式判斷某個(gè)選項(xiàng)是否被選中來(lái)返回值,但是當(dāng)一組 checkbox 只有一個(gè)選項(xiàng)時(shí),獲取值的方式又有變化,代碼中以 (checkbox.checked)?checkbox.value:''; 的方式直接判斷是否選中,然后返回對(duì)應(yīng)值。
上面的代碼傳入的參數(shù)是 checkbox 對(duì)象,如:
復(fù)制代碼 代碼如下:
var checkboxTest = document.forms['testForm'].elements['checkboxTest'];
if (getCheckboxValue(checkboxTest) == '')
{ ...... }
根據(jù)判斷結(jié)果執(zhí)行你想要的操作。
相關(guān)文章
JavaScript Select和Option列表元素上下左右移動(dòng)
支持一次選中多項(xiàng)在左右列表中來(lái)回移動(dòng)2008-12-12javascript 焦點(diǎn)的兩個(gè)問(wèn)題
# 頁(yè)面加載完后,光標(biāo)自動(dòng)定位到R0表單 # 問(wèn)題二:在R0表單輸入1,回車后跳轉(zhuǎn)到R1,輸入2回車后跳轉(zhuǎn)到R2,輸入3回車后跳轉(zhuǎn)到R32009-07-07JavaScript實(shí)現(xiàn)動(dòng)態(tài)增加文件域表單
對(duì)于上傳多個(gè)文件,可以通過(guò)js來(lái)動(dòng)態(tài)生成文件域,下面是源代碼,收藏在這里,供以后直接使用,hoho!2009-02-02js form action動(dòng)態(tài)修改方法
js修改form的action屬性的函數(shù)2008-11-11select 控制網(wǎng)頁(yè)內(nèi)容隱藏于顯示的實(shí)現(xiàn)代碼
js下通過(guò)select的控制實(shí)現(xiàn)內(nèi)容的隱藏于顯示,需要的朋友可以參考下。2010-05-05