3
有人可以幫助我,如何停止點擊事件時在裏面點選複選框兩次?我試圖添加e.stopPropagation函數,但它不起作用。li標籤中的複選框必須點擊兩次以取消選中
<div class="dropdown">
<button class="btn btn-default dropdown-toggle" type="button" id="dropdownMenu1" data-toggle="dropdown" aria-haspopup="true" aria-expanded="true">
Obor
<span class="caret"></span>
</button>
<ul class="dropdown-menu" aria-labelledby="dropdownMenu1">
<li class="dropdown-submenu"><a tabindex="-1" href="#">Automotive </a>
<ul class="dropdown-menu">
<li class="small" data-value="option2" tabIndex="-1"><input type="checkbox" checked/> Automobily </li>
<li class="small" data-value="option3" tabIndex="-1"><input type="checkbox" checked/> Nákladní auta </li>
<li class="small" data-value="option4" tabIndex="-1"><input type="checkbox" checked/> Autobusy </li>
<li class="small" data-value="option5" tabIndex="-1"><input type="checkbox" checked/> Prodej ojetých vozů </li>
<li class="small" data-value="option6" tabIndex="-1"><input type="checkbox" checked/> Komponenty </li>
<li class="small" data-value="option7" tabIndex="-1"><input type="checkbox" checked/> Alternativní pohony </li>
</ul></li></ul></div>
的Javascript:
var options = [];
$('.dropdown-menu .small').on('click', function(event) {
var $target = $(event.currentTarget),
val = $target.attr('data-value'),
$inp = $target.find('input'),
idx;
if ((idx = options.indexOf(val)) > -1) {
options.splice(idx, 1);
setTimeout(function() { $inp.prop('checked', false) }, 0);
} else {
options.push(val);
setTimeout(function() { $inp.prop('checked', true) }, 0);
}
$(event.target).blur();
console.log(options);
return false;
});