【发布时间】:2022-01-16 17:37:04
【问题描述】:
如果我检查父级然后所有子级都选中但我单击子级然后子子级将被检查,我正在创建与父级子级和子级的层次关系列表。一切正常,但在第二次点击时它的工作在第一次点击时不起作用。 这是我的小提琴示例。 小提琴链接在这里http://jsfiddle.net/fahadsheikh/qdkwy0s7/8/
function changeCategoryStatus(_this, id) {
var main = document.querySelector(".main-checkbox"+id);
var children = document.querySelectorAll(".sub-checkbox"+id);
function toggleCheck() {
var array=[];
children.forEach(child => {
if($(this).prop("checked") == true){
child.checked = child.checked = true
}
else if($(this).prop("checked") == false){
child.checked = child.checked = false
}
array.push(child.value);
})
return array;
}
if(main){
main.addEventListener("click", toggleCheck);
}
//for sub-parent category
var sub_parent = document.querySelector(".sub-parent"+id);
var sub_children = document.querySelectorAll(".sub-checkbox"+id);
function toggleCheck() {
var array=[];
sub_children.forEach(child => {
if($(this).prop("checked") == true){
child.checked = child.checked = true
}
else if($(this).prop("checked") == false){
child.checked = child.checked = false
}
array.push(child.value);
})
return array;
}
if(sub_parent){
sub_parent.addEventListener("click", toggleCheck);
}
var status = $(_this).prop('checked') == true ? 'active' : 'inactive';
$.ajax({
type: 'POST',
url:"{{url('admin/categories-status')}}",
data: {
id: id,
status: status,
_token: "{{ csrf_token() }}"
},
success: function (result) {
$("#status-success").show();
$("#status-success").html(result.success);
setTimeout(function() {
$("#status-success").hide()
}, 3000);
}
});
}
body {
background: #20262E;
padding: 20px;
font-family: Helvetica;
}
#banner-message {
background: #fff;
border-radius: 4px;
padding: 20px;
font-size: 25px;
text-align: center;
transition: all 0.2s;
margin: 0 auto;
width: 300px;
}
button {
background: #0084ff;
border: none;
border-radius: 5px;
padding: 8px 14px;
font-size: 15px;
color: #fff;
}
#banner-message.alt {
background: #0084ff;
color: #fff;
margin-top: 40px;
width: 200px;
}
#banner-message.alt button {
background: #fff;
color: #000;
}
<div class="sortable">
<div class="group-caption">
<li class="main-parent category-sortable main-item" data-parent="4" data-position="4" data-newposition="1">second room
<span class="buttons-align">
<label class="switch">
<input class="main-checkbox4" type="checkbox" id="user-4"
onclick="changeCategoryStatus(event.target, 4);"
>
<span class="slider round"></span>
</label>
</span>
<div class="move" id="item-move" ><i class="fa fa-bars" aria-hidden="true"></i></div></li>
<ul class="group-items group-items-parent">
<li class="group-item-parent category-sortable" data-parent="5" data-position="1" data-newposition="1">second-child room
<span class="buttons-align">
<label class="switch">
<input class="sub-checkbox4 sub-parent4" type="checkbox" id="user-5"
onclick="changeCategoryStatus(event.target, 5);"
>
<span class="slider round"></span>
</label>
</span>
<div class="move"><i class="fa fa-bars" aria-hidden="true"></i></div></li>
<ul class="group-items-child">
<li class="group-item-child category-sortable" data-parent="6" data-position="1" data-newposition="0">second subchild
<span class="buttons-align">
<label class="switch">
<input class="sub-checkbox4" type="checkbox" id="user-6"
onclick="changeCategoryStatus(event.target, 6);"
>
<span class="slider round"></span>
</label>
</span>
<div class="move"><i class="fa fa-bars" aria-hidden="true"></i></div></li>
</ul>
</ul>
</div>
<div class="group-caption">
<li class="main-parent category-sortable main-item" data-parent="7" data-position="4" data-newposition="2">third-room
<span class="buttons-align">
<label class="switch">
<input class="main-checkbox7" type="checkbox" id="user-7"
onclick="changeCategoryStatus(event.target, 7);"
>
<span class="slider round"></span>
</label>
</span>
<div class="move" id="item-move" ><i class="fa fa-bars" aria-hidden="true"></i></div></li>
<ul class="group-items group-items-parent">
<li class="group-item-parent category-sortable" data-parent="9" data-position="1" data-newposition="1">third-child
<span class="buttons-align">
<label class="switch">
<input class="sub-checkbox7 sub-parent7" type="checkbox" id="user-9"
onclick="changeCategoryStatus(event.target, 9);"
>
<span class="slider round"></span>
</label>
</span>
<div class="move"><i class="fa fa-bars" aria-hidden="true"></i></div></li>
<ul class="group-items-child">
<li class="group-item-child category-sortable" data-parent="10" data-position="1" data-newposition="0">third-subchild
<span class="buttons-align">
<label class="switch">
<input class="sub-checkbox7" type="checkbox" id="user-10"
onclick="changeCategoryStatus(event.target, 10);"
>
<span class="slider round"></span>
</label>
</span>
<div class="move"><i class="fa fa-bars" aria-hidden="true"></i></div></li>
</ul>
</ul>
</div>
</div>
感谢您的帮助。
【问题讨论】:
标签: javascript html jquery jquery-ui checkboxlist