当前位置: 首页 > 知识库问答 >
问题:

如果选中了一个特定的复选框,则禁用其他复选框jQuery

耿弘阔
2023-03-14

我有一组单选按钮,如果选中“no”,它会显示一个包含6个复选框(不同的名称/ID)的DIV。如果选中“none”,我需要禁用其他复选框(如果不选中“none”,则再次启用)。我还需要标签将类text-black-50添加到禁用的复选框中,就像我在下面的“添加到笔记本电脑的代码”复选框中所做的那样。

下面是我的演示:

null

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>

null

我怎样才能把这个和我在这里面的其他脚本结合起来呢?

共有1个答案

华善
2023-03-14

这将起作用:

$('#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://jsfidle.net/s75ypcun/2/

 类似资料:
  • 选中“第一键”复选框时,我想选中并禁用“第二键”复选框 html代码 为复选框键入脚本代码 } 通过使用此代码,key 2复选框被选中并禁用。但是key 2复选框的布尔值仍然是假的。当我单击key 1复选框时,关于如何将key 2复选框的布尔值更改为true的任何建议我正在使用Angular 8及其反应式形式模块。我是角度新手。

  • 我试图创建一个表单,该表单顶部有一个复选框,当用户选中该复选框时,它会选择其他特定的复选框,但不是所有复选框。我很难通过反复试验或搜索找到答案。我唯一能找到的就是“全选”选项。不是我想要的。 理想情况下,当用户选中“管理包”旁边的复选框时,我想要“Chrome外观组”和“远程启动” 下面是代码和我在这方面的基本尝试,但它不起作用。提前谢谢。 超文本标记语言: Javascript 我不知道这个Ja

  • 如果选中复选框D并取消选中其他复选框,我希望选中复选框K和F。同样,如果选中复选框I,则前面的复选框I将被选中,下面的复选框将被取消选中。我的html代码是: 我为此所做的是: 这看起来很乱,还有一个很酷的过程吗???

  • 我创建了一个windows窗体(到目前为止)只包含复选框。构造函数接受一个参数:。对于这个数组中的每个字符串,我都会创建一个复选框。 例如: null 那么,当另一个复选框调用uncheck时,是否有一种方法可以告诉我的复选框不要运行? 下面是我的代码(它都是手工编写的,所以没有使用visual studio设计器):

  • 我正在尝试一个Woocommerce票证插件。默认情况下,该插件会显示一个表,其中包含多个票证变体作为产品,并在下面显示一个文本字段作为其数量和一个提交按钮,以将产品添加到购物车中。 我想用单选按钮或复选框替换这个文本字段,这样用户就可以选择一种类型的票证,然后点击提交按钮将其中的一部分添加到购物车中。 我的想法是在foreach循环中创建一个复选框或单选按钮,该复选框或单选按钮的值为quanti

  • 问题内容: 如何在我的HTML表单中启用“提交”按钮,以及如果未选中此复选框则如何禁用? 此代码有什么问题? 复选框 问题答案: 将您的HTML更改为此: 原因不起作用:您没有传递任何函数。实际上,由于您没有在函数名称中使用括号,因此根本就没有调用函数。在HTML事件属性的上下文中传递它意味着您正在传递对该元素的DOM对象的引用,从而使您可以访问其属性。