我使用AJAX将多行添加到包含复选框的数据表中 作为一个元素。我已经为之后的复选框编写了代码 选择/取消选择&select-all',tbody中的所有子复选框都应该获得 相应地选中或取消选中..在手动选择/取消选中任何子复选框后,选择全部'复选框应该改变。但这部分不起作用。
HTML CODE:
<table id="user" class="w3-table-all w3-hoverable w3-card-4 display">
<thead>
<tr class="w3-light-grey">
<th><input type="checkbox" class="w3-check" id="select-all"></th>
<th>User Id</th>
<th>Username</th>
<th>Full Name</th>
<th>Activated Date</th>
<th>Last Login Date</th>
</tr>
</thead>
<tbody id="body">
</tbody>
</table>
JQuery for checkboxes:
$("#select-all").change(function(){
$(".checkbox").prop('checked', $(this).prop("checked"));
});
$('.checkbox').change(function(){
if(false == $(this).prop("checked")){
$("#select-all").prop('checked', false);
}
if ($('.checkbox:checked').length == $('.checkbox').length ){
$("#select-all").prop('checked', true);
}
});
DATATABLE和AJAX功能代码:
var table = $('#user').DataTable({
"columns": [
{ "orderable": false },
null,
null,
null,
null,
null,
],
"order": [[ 1, "asc" ]]
});
$.ajax({
url: 'data.json',
dataType: 'json',
success: function(data) {
for (var i=0; i<data.length; i++) {
if(data[i].enabled==1)
var row1 = $('<tr><td><input type="checkbox" class="w3-check checkbox" value=""></td><td>' + data[i].id+ '</td><td>' + data[i].username + '</td><td>' + data[i].first_name + ' ' + data[i].middle_name + ' ' + data[i].last_name + '</td><td>' + data[i].activated_date + '</td><td>' + data[i].last_login + '</td></tr>');
table.rows.add(row1);
table.draw();
$("#body").append(row1);
}
},
error: function(jqXHR, textStatus, errorThrown){
alert('Error: ' + textStatus + ' - ' + errorThrown);
}
});
答案 0 :(得分:1)
试试此代码
$("#user").on("click", "#select-all").change(function(){
$(".checkbox").prop('checked', $(this).prop("checked"));
});
$("#user").on("click", ".checkbox", function() {
$("#select-all").prop('checked', true)
$("#user").find(".checkbox").each(function() {
if (!$(this).prop('checked')){
$("#select-all").prop('checked', false);
return;
}
})
})
以下是示例代码
$(function() {
//handler for selectall change
$('#selectAll').change(function() {
$("input[name='msisdn[]']").prop('checked', $(this).prop('checked'))
})
//handler for all checkboxes to refect selectAll status
$("input[name='msisdn[]']").change(function() {
$("#selectAll").prop('checked', true)
$("input[name='msisdn[]']").each(function() {
if (!$(this).prop('checked')){
$("#selectAll").prop('checked', $(this).prop('checked'));
return;
}
})
})
})
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="multiple_msisdn">
<label class="exp">
<input type="checkbox" class="exp" id="selectAll"> -- Select All -- </label>
<label class="exp">
<input type="checkbox" class="exp" name="msisdn[]" value="1"> ABC [xxxxxxxx]</label>
<label class="exp">
<input type="checkbox" class="exp" name="msisdn[]" value="18"> ABC [xxxxxx]</label>
</div>