Щелчок флажка не работает из элемента неупорядоченного списка

Я не могу «отметить» флажок ввода, встроенный в расширяемую UL. Я знаю, что причина как-то связана с привязкой кликов, но я просто не могу этого понять.

UL является динамическим, поэтому я добавляю новые li и UL. UL самого низкого уровня содержит списки, которые должны быть доступны для выбора. Однако, когда я пытаюсь щелкнуть по ним, он просто выделяет метку, и флажок никогда не устанавливается.

Вот 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()
    });

person silvster27    schedule 25.08.2012    source источник
comment
Можете ли вы создать jsfiddle.net?   -  person Priyank Patel    schedule 25.08.2012
comment
Что ж, события щелчка всплывают в DOM, и return false; из обработчика кликов останавливает поведение по умолчанию для клика, так что... почему вы возвращаете false? Вы можете добавить if (event.target.tagName.toLowerCase()==="input") return; (без false) в начало вашего обработчика кликов, чтобы остановить дальнейшую обработку при нажатии на ввод (включая флажки). Или if ($(event.target).is("input")) return;, если вы думаете, что в моем первом предложении недостаточно jQuery...   -  person nnnnnn    schedule 25.08.2012


Ответы (1)


Вы возвращаете false из события li click, поэтому событие никогда не попадает в флажок. Просто удалите строку return false; из обработчика событий и чекбокс заработает нормально. Вот jsFiddle.

person mhusaini    schedule 25.08.2012
comment
Я понимаю! Не могу поверить, что я пропустил это. Единственная проблема заключается в том, что если я удалю return false, события щелчка будут всплывать, что приведет к множеству «переключателей», но вместо этого я смог использовать event.stoppropogation(), и теперь все работает. Спасибо! - person silvster27; 27.08.2012
comment
Правильно, return false; имеет комбинированный эффект вызова event.stopPropagation() и event.preventDefault() вместе. Поскольку вам нужен только первый, имеет смысл вызвать его явно. - person mhusaini; 28.08.2012