我无法“检查”嵌入在可扩展UL中的输入复选框。我知道原因与点击绑定有关,但我无法弄明白。
UL是动态的,所以我添加了新的li和UL。最低级别UL包含应该可选择的lis。但是,当我尝试单击它们时,它只会突出显示标签,并且永远不会检查复选框。
这是HTML:
<li id="JeffID4" class="collapsed expanded">
Assessment
<ul class="inputs-list" style="display: block;">
<li id="apple">
<label class="checkbox inline">
<input type="checkbox">
ATGM
</label>
</li>
<li id="apple">
<label class="checkbox inline">
<input type="checkbox">
FMS
</label>
</li>
</ul>
</li>
这是javascript / jquery:
function prepareList() {
$('#expList').find('li:has(ul)')
.click( function(event) {
//If line item is expandable but has no line items then call the service to retrieve data
if($(event.target).hasClass('collapsed') && $(event.target).find('li').length==0){
$(event.target).children('ul').append("Add New LI's")
$('#expList').find('li:has(ul)').addClass('collapsed');
$('#expList').find('ul').addClass('inputslist'); $(event.target).find('li:has(input)').unbind();
$(event.target).children('ul').hide();
}
//Toggle the lists if they show or not
$(event.target).toggleClass('expanded');
$(event.target).children('ul').slideToggle('medium');
return false;
})
.addClass('collapsed').removeClass('expanded').children('ul').hide();
};
$(document).ready( function() {
prepareList()
});
答案 0 :(得分:1)
您将从false
li
事件返回click
,因此该事件永远不会进入复选框。只需从事件处理程序中删除行return false;
,该复选框即可正常工作。这是一个jsFiddle。