取消选中 "Check all" 复选框
Uncheck a "Check all" Checkbox
我做了一个 table,在行的开头有一个复选框。我还制作了一个 "Check All" 复选框。当它是 "checked" 时,table 上的所有其他复选框都将被选中。那很好用。但是,当我在 table 上 "unchecked" 一个复选框时,"Check All" 复选框仍然是 "checked"。当其他复选框之一更改时,如何取消选中它?
我的代码在这里:
脚本:
$('#chkall').change(function() {
var checkboxes = $(this).closest('table').find(':checkbox');
if($(this).is(':checked')) {
checkboxes.prop('checked', true);
} else {
checkboxes.prop('checked', false);
}
});
Table (html):
<table class="table table-hover">
<tr>
<th><input type ="checkbox" id = "chkall"></th>
<th>Type</th>
<th>Brand</th>
<th>Description</th>
<th>Serial No</th>
<th>Asset No</th>
<th>Date of Purchased</th>
<th>Warranty Expiration</th>
<th>Status</th>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
</table>
您可以只添加此事件处理程序:
$('#chkall').closest('table').on('change', ':checkbox:not(#chkall)', function() {
if (!$(this).is(':checked'))
$('#chkall').prop('checked', false);
});
您可以将复选框的数量与 已选中 的复选框的数量进行比较。
如果触发 change
事件时数字不相等,请取消选中 #chkall
元素:
$('table :checkbox:not(#chkall)').on('change', function () {
if ($(this).length !== $(this).closest('table').find(':checked:not(#chkall)').length) {
$('#chkall').prop('checked', false);
}
});
为清除全选框的所有其他复选框添加处理程序。
$(":checkbox:not(#chkall)").change(function() {
if (!this.checked) {
$("#chkall").prop("checked", false);
}
});
尝试将复选框的数量与选中的复选框的数量进行比较
$('table').on('change', ':checkbox:not(#chkall)', function(){
var checkboxes = $(this).closest('table').find(':checkbox:not(#chkall)'),
allchecked = (checkboxes.length === checkboxes.filter(':checked').length);
$('#chkall').prop('checked', allchecked);
});
如果您手动选中单个复选框,此代码还将启用全选
完整示例
$('#chkall').change(function() {
var checkboxes = $(this).closest('table').find(':checkbox');
if ($(this).is(':checked')) {
checkboxes.prop('checked', true);
} else {
checkboxes.prop('checked', false);
}
});
$('table').on('change', ':checkbox:not(#chkall)', function() {
var checkboxes = $(this).closest('table').find(':checkbox:not(#chkall)'),
allchecked = (checkboxes.length === checkboxes.filter(':checked').length);
$('#chkall').prop('checked', allchecked);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<table class="table table-hover">
<tr>
<th>
<input type="checkbox" id="chkall">
</th>
<th>Type</th>
<th>Brand</th>
<th>Description</th>
<th>Serial No</th>
<th>Asset No</th>
<th>Date of Purchased</th>
<th>Warranty Expiration</th>
<th>Status</th>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
</table>
像这样尝试向所有复选框添加另一个更改事件
$('.yourcheckboxclass').change(function() { });
或
$('#yourtable input:checkbox').change(function() { });
在函数内部,select 你的 #chkall 并取消选中它。
尝试这样的事情:
$('#chkall').on("change", function() {
if (!$(this).is(':checked')) {
$('.selectRow').prop('checked', false);
} else {
$('.selectRow').prop('checked', true);
}
});
$('.selectRow').each(function( index ){
$(this).on("change", function(){
if (!$(this).is(':checked')) {
$('#chkall').prop('checked', false);
}
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table>
<thead>
<tr>
<th>
<input type="checkbox" id="chkall" >Check All</input>
</th>
</tr>
</thead>
<tbody>
<tr>
<td>
<input type="checkbox" class="selectRow" />
</td>
</tr>
<tr>
<td>
<input type="checkbox" class="selectRow" />
</td>
</tr>
</tbody>
</table>
我做了一个 table,在行的开头有一个复选框。我还制作了一个 "Check All" 复选框。当它是 "checked" 时,table 上的所有其他复选框都将被选中。那很好用。但是,当我在 table 上 "unchecked" 一个复选框时,"Check All" 复选框仍然是 "checked"。当其他复选框之一更改时,如何取消选中它?
我的代码在这里:
脚本:
$('#chkall').change(function() {
var checkboxes = $(this).closest('table').find(':checkbox');
if($(this).is(':checked')) {
checkboxes.prop('checked', true);
} else {
checkboxes.prop('checked', false);
}
});
Table (html):
<table class="table table-hover">
<tr>
<th><input type ="checkbox" id = "chkall"></th>
<th>Type</th>
<th>Brand</th>
<th>Description</th>
<th>Serial No</th>
<th>Asset No</th>
<th>Date of Purchased</th>
<th>Warranty Expiration</th>
<th>Status</th>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td><input type ="checkbox"></td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
</table>
您可以只添加此事件处理程序:
$('#chkall').closest('table').on('change', ':checkbox:not(#chkall)', function() {
if (!$(this).is(':checked'))
$('#chkall').prop('checked', false);
});
您可以将复选框的数量与 已选中 的复选框的数量进行比较。
如果触发 change
事件时数字不相等,请取消选中 #chkall
元素:
$('table :checkbox:not(#chkall)').on('change', function () {
if ($(this).length !== $(this).closest('table').find(':checked:not(#chkall)').length) {
$('#chkall').prop('checked', false);
}
});
为清除全选框的所有其他复选框添加处理程序。
$(":checkbox:not(#chkall)").change(function() {
if (!this.checked) {
$("#chkall").prop("checked", false);
}
});
尝试将复选框的数量与选中的复选框的数量进行比较
$('table').on('change', ':checkbox:not(#chkall)', function(){
var checkboxes = $(this).closest('table').find(':checkbox:not(#chkall)'),
allchecked = (checkboxes.length === checkboxes.filter(':checked').length);
$('#chkall').prop('checked', allchecked);
});
如果您手动选中单个复选框,此代码还将启用全选
完整示例
$('#chkall').change(function() {
var checkboxes = $(this).closest('table').find(':checkbox');
if ($(this).is(':checked')) {
checkboxes.prop('checked', true);
} else {
checkboxes.prop('checked', false);
}
});
$('table').on('change', ':checkbox:not(#chkall)', function() {
var checkboxes = $(this).closest('table').find(':checkbox:not(#chkall)'),
allchecked = (checkboxes.length === checkboxes.filter(':checked').length);
$('#chkall').prop('checked', allchecked);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<table class="table table-hover">
<tr>
<th>
<input type="checkbox" id="chkall">
</th>
<th>Type</th>
<th>Brand</th>
<th>Description</th>
<th>Serial No</th>
<th>Asset No</th>
<th>Date of Purchased</th>
<th>Warranty Expiration</th>
<th>Status</th>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
<tr>
<td>
<input type="checkbox">
</td>
<td>Keyboard</td>
<td>HP</td>
<td>One time use keyboard</td>
<td>123456</td>
<td>789456</td>
<td>July 5, 2019</td>
<td>August 6, 2015</td>
<td>Available</td>
</tr>
</table>
像这样尝试向所有复选框添加另一个更改事件
$('.yourcheckboxclass').change(function() { });
或
$('#yourtable input:checkbox').change(function() { });
在函数内部,select 你的 #chkall 并取消选中它。
尝试这样的事情:
$('#chkall').on("change", function() {
if (!$(this).is(':checked')) {
$('.selectRow').prop('checked', false);
} else {
$('.selectRow').prop('checked', true);
}
});
$('.selectRow').each(function( index ){
$(this).on("change", function(){
if (!$(this).is(':checked')) {
$('#chkall').prop('checked', false);
}
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table>
<thead>
<tr>
<th>
<input type="checkbox" id="chkall" >Check All</input>
</th>
</tr>
</thead>
<tbody>
<tr>
<td>
<input type="checkbox" class="selectRow" />
</td>
</tr>
<tr>
<td>
<input type="checkbox" class="selectRow" />
</td>
</tr>
</tbody>
</table>