簡體   English   中英

如果選中了一個特定選項,則禁用其他復選框 jQuery

[英]Disable other checkboxes if one specific is checked jQuery

我有一組單選按鈕,如果選擇“否”,它會顯示一個帶有 6 個復選框(不同名稱/ID)的 DIV,如果選中“無”,我需要禁用其他按鈕(如果“無”則再次啟用未選中)我還需要 label 將 class text-black-50添加到禁用的復選框中,就像我在以下代碼中添加到筆記本電腦復選框一樣。

這是我所擁有的演示:

 function toggleRequired() { var isITNoChecked = $('#StandardITPackageNo').is(':checked'); $('[name="Laptop"').prop('required', isITNoChecked); } function toggleHidden() { var isITNoChecked = $('#StandardITPackageNo').is(':checked'); $('#StandardITPackage').toggleClass('hidden', ;isITNoChecked). } $('[name="Laptop"]'),on('change'; function() { toggleRequired(); toggleHidden(); }). $('[name="StandardITPackage"]'),on('change'; function() { toggleRequired(); toggleHidden(); }). function CompanyITPackageFunction() { var x = document;getElementById("StandardITPackage"). if (x.style.display === "none") { x.style;display = "block". } else { x.style;display = "none". } } function CompanyITPackageFunctionClose() { var x = document;getElementById("StandardITPackage"). if (x.style.display === "none") { x.style;display = "none". } else { x.style;display = "none"; } }
 .hidden { display: none; }
 <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.6.0/dist/css/bootstrap.min.css" integrity="sha384-B0vP5xmATw1+K9KRQjQERJvTumQW0nPEzvF6L/Z6nronJ3oUOFUFpCjEUQouq2+l" crossorigin="anonymous"> <table> <tr> <td><b>Standard IT Package? :</b></td> <td> <label class="container" style="margin-top: 15px;">Ja <input type="radio" id="StandardITPackageYes" name="StandardITPackage" value="yes" data-parsley-errors-container="#CompanyITPackage-errors" required> <span class="radio"></span> </label> </td> <td> <label class="container" style="margin-top: 15px;">Nej <input type="radio" id="StandardITPackageNo" name="StandardITPackage" value="no"> <span class="radio"></span> </label> </td> </tr> </table> <div id="StandardITPackage" class="hidden"> <br> <table cellpadding="6" valign="top" style="width: 400px;"> <tr style="border-bottom: 0px solid #FFFFFF;"> <td> <label class="container text-black-50">Laptop <input type="checkbox" id="Laptop" name="Laptop" value="yes" data-parsley-checkmin="1" data-parsley-errors-container="#equipment-errors" data-parsley-error-message="Der skal vælges minimum ét felt" data-parsley-multiple="equipment" required> <span class="checkmark"></span> </label> </td> <td> <label class="container">Headset <input type="checkbox" id="Headset" name="Headset" value="yes" data-parsley-multiple="equipment"> <span class="checkmark"></span> </label> </td> </tr> <tr style="border-bottom: 0px solid #FFFFFF;"> <td> <label class="container">Mus & Tastatur <input type="checkbox" id="MouseKeyboard" name="MouseKeyboard" value="yes" data-parsley-multiple="equipment"> <span class="checkmark"></span> </label> </td> <td> <label class="container">DockingStation <input type="checkbox" id="DockingStation" name="DockingStation" value="yes" data-parsley-multiple="equipment"> <span class="checkmark"></span> </label> </td> </tr> <tr style="border-bottom: 0px solid #FFFFFF;"> <td> <label class="container">Display <input type="checkbox" id="Display" name="Display" value="yes" data-parsley-multiple="equipment"> <span class="checkmark"></span> </label> </td> <td> <label class="container"><i>None</i> <input type="checkbox" id="NoEquipMent" name="NoEquipMent" value="yes" data-parsley-multiple="equipment"> <span class="checkmark"></span> </label> </td> </tr> </table> <script src="https://code.jquery.com/jquery-3.5.1.slim.min.js" integrity="sha384-DfXdz2htPH0lsSSs5nCTpuj/zy4C+OGpamoFVy38MVBnE+IbbVYUew+OrCXaRkfj" crossorigin="anonymous"></script> <script src="https://cdn.jsdelivr.net/npm/bootstrap@4.6.0/dist/js/bootstrap.bundle.min.js" integrity="sha384-Piv4xVNRyMGpqkS2by6br4gNJ7DXjqk09RmUpJ8jgGtD7zP9yug3goQfGII0yAns" crossorigin="anonymous"></script>

我怎樣才能將它與我在其中的其他腳本結合起來?

這可以解決問題:

$('#NoEquipMent').on('click', function(){
    var checkboxes = $(this).closest('table').find(':checkbox:not(:last)');
    var labels = $(this).closest('table').find('label:not(:last)');

    if($(this).is(':checked')){
        checkboxes.attr('disabled', 'disabled');
        labels.addClass('text-black-50');
    }
    else{
        checkboxes.removeAttr('disabled');
        labels.removeClass('text-black-50');
    }
});

https://jsfiddle.net/s75ypcun/2/

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM