Javascript 驗證單選(radio)值 和多選框

來源:互聯網
上載者:User

 

 

<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) == '')
    { ...... }

    根據判斷結果執行你想要的操作。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.