我正在創建與父子項和子子項的層次關系串列,如果我選中父項,然后選中所有子項,但我單擊子項,則將檢查子子項。一切正常,但它在第二次點擊時的作業在第一次點擊時不起作用。這是我的小提琴示例。小提琴鏈接在這里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>
感謝幫助。
uj5u.com熱心網友回復:
您當前邏輯的主要問題是每次單擊toggleCheck()復選框時都將函式附加到主復選框。這會導致您看到的奇怪行為。
另請注意,您的 HTML 無效。li元素必須是孩子們ul唯一的,不能div和ul本身不能成為另一個孩子ul。您需要正確構建嵌套串列。您還可以通過洗掉增量 id 和 class 屬性來改進 HTML。它們是一種反模式,會導致不必要的復雜代碼。使用 DOM 遍歷來關聯元素。
關于 JS 代碼,您應該避免使用行內onclick事件處理程式,因為它們不再是好的做法。使用通過 JS 邏輯添加的不顯眼的事件處理程式。您還toggleCheck()多次重新定義該函式,這是一種很大的代碼味道。
綜上所述,HTML 和 JS 可以大大簡化:
$('.sortable :checkbox').on('change', e => {
let $cb = $(e.target);
let isChecked = $cb.prop('checked');
$cb.closest('li').find(':checkbox').prop('checked', isChecked);
/*
// AJAX commented out for this demo only
$.ajax({
type: 'POST',
url: "{{url('admin/categories-status')}}",
data: {
id: $cb.prop('id'),
status: isChecked ? 'active' : 'inactive',
_token: "{{ csrf_token() }}"
},
success: function(result) {
$("#status-success").html(result.success).show();
setTimeout(function() {
$("#status-success").hide();
}, 3000);
}
});
*/
});
body {
/* background-color: #20262E; */
padding: 20px;
font-family: Helvetica;
}
.move {
display: inline-block;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<link rel="stylesheet" href="https://pro.fontawesome.com/releases/v5.10.0/css/all.css" integrity="sha384-AYmEC3Yw5cVb3ZcuHtOA93w35dYTsvhLPVnYs9eStHfGJvOvKxVfELGroGkvsg p" crossorigin="anonymous"/>
<div class="sortable">
<ul 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 type="checkbox" id="4" />
<span class="slider round"></span>
</label>
</span>
<div class="move">
<i class="fa fa-bars" aria-hidden="true"></i>
</div>
<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 type="checkbox" id="5" />
<span class="slider round"></span>
</label>
</span>
<div class="move">
<i class="fa fa-bars" aria-hidden="true"></i>
</div>
<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 type="checkbox" id="6" />
<span class="slider round"></span>
</label>
</span>
<div class="move"><i class="fa fa-bars" aria-hidden="true"></i></div>
</li>
</ul>
</li>
</ul>
</li>
</ul>
<ul 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 type="checkbox" id="7" />
<span class="slider round"></span>
</label>
</span>
<div class="move">
<i class="fa fa-bars" aria-hidden="true"></i>
</div>
<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 type="checkbox" id="9" />
<span class="slider round"></span>
</label>
</span>
<div class="move">
<i class="fa fa-bars" aria-hidden="true"></i>
</div>
<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 type="checkbox" id="10" />
<span class="slider round"></span>
</label>
</span>
<div class="move">
<i class="fa fa-bars" aria-hidden="true"></i>
</div>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/380016.html
標籤:javascript html 查询 jquery-ui 复选框列表
下一篇:我怎樣才能讓組件接受里面的元素?
