本文介紹了一個較為通用的擷取 checkbox 值的方法,希望對新手有用。
複製代碼 代碼如下:<script type="text/javascript">
// 說明: 用 Javascript 驗證表單(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 相同,值有多個,在擷取 checkbox 值的時候,我們不能按照普通文字框 .value 的方式,而是要判斷哪個被選中了。
當一組 checkbox 有多個選項時,我們可以通過迴圈,以 checkbox[i] 的方式判斷某個選項是否被選中來傳回值,但是當一組 checkbox 只有一個選項時,擷取值的方式又有變化,代碼中以 (checkbox.checked)?checkbox.value:''; 的方式直接判斷是否選中,然後返回對應值。
上面的代碼傳入的參數是 checkbox 對象,如: 複製代碼 代碼如下:var checkboxTest = document.forms['testForm'].elements['checkboxTest'];
if (getCheckboxValue(checkboxTest) == '')
{ ...... }
根據判斷結果執行你想要的操作。