jQuery - прапорець включити / відключити


234

У мене є купа таких прапорців. Якщо прапорець "Перевірити мене" встановлений, усі інші 3 прапорці повинні бути включені, інакше їх слід вимкнути. Як це зробити за допомогою jQuery?

<form name="frmChkForm" id="frmChkForm">
<input type="checkbox" name="chkcc9">Check Me
<input type="checkbox" name="chk9[120]">
<input type="checkbox" name="chk9[140]">
<input type="checkbox" name="chk9[150]">
</form>

Відповіді:


413

Трохи змінити розмітку:

$(function() {
  enable_cb();
  $("#group1").click(enable_cb);
});

function enable_cb() {
  if (this.checked) {
    $("input.group1").removeAttr("disabled");
  } else {
    $("input.group1").attr("disabled", true);
  }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<form name="frmChkForm" id="frmChkForm">
  <input type="checkbox" name="chkcc9" id="group1">Check Me <br>
  <input type="checkbox" name="chk9[120]" class="group1"><br>
  <input type="checkbox" name="chk9[140]" class="group1"><br>
  <input type="checkbox" name="chk9[150]" class="group1"><br>
</form>

Це можна зробити за допомогою селекторів атрибутів, не вводячи ідентифікатор та класи, але це повільніше і (що не важче) читати.


3
Для вимкнення частини спробуйте цю URL-адресу: jquery-howto.blogspot.com/2008/12/…
Уолт Стоунбернер

3
Це не пов’язано безпосередньо з питанням, але в IE подія зміни не запуститься, поки прапорець не втратить фокус. Зазвичай я закликаю $(this).changeподія клацання першого прапорця.
mcrumley

10
ви можете використовувати .prop()замість .attr().
Reza Owliaei

5
У мене були проблеми з .prop (), він працював на початковому наборі, але якщо я перемикався вперед і назад, другий раз не вдалося "відключити" прапорець. Я застряг з attr ().
ProVega


100

Це найсучасніше рішення.

<form name="frmChkForm" id="frmChkForm">
    <input type="checkbox" name="chkcc9" id="group1" />Check Me
    <input type="checkbox" name="chk9[120]" class="group1" />
    <input type="checkbox" name="chk9[140]" class="group1" />
    <input type="checkbox" name="chk9[150]" class="group1" />
</form>

$(function() {
    enable_cb();
    $("#group1").click(enable_cb);
});

function enable_cb() {
    $("input.group1").prop("disabled", !this.checked);
}

Ось деталі використання для .attr()та .prop().

jQuery 1.6+

Використовуйте нову .prop()функцію:

$("input.group1").prop("disabled", true);
$("input.group1").prop("disabled", false);

jQuery 1.5 і нижче

.prop()Функція не доступна, так що вам потрібно використовувати .attr().

Щоб відключити прапорець (встановивши значення відключеного атрибуту), зробіть

$("input.group1").attr('disabled','disabled');

і для включення (повністю видаливши атрибут) зробити

$("input.group1").removeAttr('disabled');

Будь-яка версія jQuery

Якщо ви працюєте лише з одним елементом, це завжди буде найшвидшим у використанні DOMElement.disabled = true. Користь від використання функцій .prop()та .attr()функцій полягає в тому, що вони будуть працювати на всіх зібраних елементах.

// Assuming an event handler on a checkbox
if (this.disabled)

ref: Установка "Позначено" для прапорця з jQuery?


2
Для тих, хто використовує asp: CheckBox, як я, він відображається в браузері як вхід в межах періоду. Тож у моєму випадку мені довелося отримати доступ до jQuery як $ ('. CheckboxClassName input'). Prop ('вимкнено', false) ... і спроба змінити 'включений' також не працювала для мене :) Дякую за цю відповідь!
поглиблення

10
<form name="frmChkForm" id="frmChkForm">
<input type="checkbox" name="chkcc9" id="chkAll">Check Me
<input type="checkbox" name="chk9[120]" class="chkGroup">
<input type="checkbox" name="chk9[140]" class="chkGroup">
<input type="checkbox" name="chk9[150]" class="chkGroup">
</form>

$("#chkAll").click(function() {
   $(".chkGroup").attr("checked", this.checked);
});

З додатковою функціональністю для забезпечення встановлення прапорець усіх прапорців, якщо всі окремі прапорці встановлені:

$(".chkGroup").click(function() {
  $("#chkAll")[0].checked = $(".chkGroup:checked").length == $(".chkGroup").length;
});

1

Ось ще один зразок із використанням JQuery 1.10.2

$(".chkcc9").on('click', function() {
            $(this)
            .parents('table')
            .find('.group1') 
            .prop('checked', $(this).is(':checked')); 
});

1

$(document).ready(function() {
  $('#InventoryMasterError').click(function(event) { //on click
    if (this.checked) { // check select status
      $('.checkerror').each(function() { //loop through each checkbox
        $('#selecctall').attr('disabled', 'disabled');
      });
    } else {
      $('.checkerror').each(function() { //loop through each checkbox
        $('#selecctall').removeAttr('disabled', 'disabled');
      });
    }
  });

});

$(document).ready(function() {
  $('#selecctall').click(function(event) { //on click
    if (this.checked) { // check select status
      $('.checkbox1').each(function() { //loop through each checkbox
        $('#InventoryMasterError').attr('disabled', 'disabled');
      });

    } else {
      $('.checkbox1').each(function() { //loop through each checkbox
        $('#InventoryMasterError').removeAttr('disabled', 'disabled');
      });
    }
  });
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="checkbox" id="selecctall" name="selecctall" value="All" />
<input type="checkbox" name="data[InventoryMaster][error]" label="" value="error" id="InventoryMasterError" />
<input type="checkbox" name="checkid[]" class="checkbox1" value="1" id="InventoryMasterId" />
<input type="checkbox" name="checkid[]" class="checkbox1" value="2" id="InventoryMasterId" />


0

$jQuery(function() {
  enable_cb();
  jQuery("#group1").click(enable_cb);
});

function enable_cb() {
  if (this.checked) {
    jQuery("input.group1").removeAttr("disabled");
  } else {
    jQuery("input.group1").attr("disabled", true);
  }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<form name="frmChkForm" id="frmChkForm">
  <input type="checkbox" name="chkcc9" id="group1">Check Me <br>
  <input type="checkbox" name="chk9[120]" class="group1"><br>
  <input type="checkbox" name="chk9[140]" class="group1"><br>
  <input type="checkbox" name="chk9[150]" class="group1"><br>
</form>

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.