1

我有一个功能,允许我通过单击列表项来展开和折叠无序列表,但问题出在最低级别的 LI 我有一个嵌入了复选框的表,当用户单击表时 [编辑]显示父 li 的背景图像。

在我看来,有两条主要途径可以解决这个问题,以某种方式仅删除子 li 的背景图像或取消绑定子 li 的单击事件。我正在尝试取消绑定最低级别 LI 上的单击处理程序,但它不起作用。下面是简化版。用户不应该能够点击 td 单元格。

如果您查看 jsfiddle,我无法添加将问题完全复制到您可以看到问题的地方的 png 文件,但只要在子 li 上触发“警报”,您就可以告诉子 li 仍然是可点击的。

http://jsfiddle.net/3CgQ6/9/

HTML

<ul id="expList">
  <li>Category 1
     <ul>
        <li class="detailLI"> Category 1.1
           <table>
             <tr><td><input type="checkbox"></td><td>Part A</td></tr>
             <tr><td><input type="checkbox"></td><td>Part B</td></tr>
             <tr><td><input type="checkbox"></td><td>Part C</td></tr>
           </table>
        </li>
        <li class="detailLI"> Category 1.2
           <table>
             <tr><td><input type="checkbox"></td><td>Part D</td></tr>
             <tr><td><input type="checkbox"></td><td>Part E</td></tr>
           </table>
        </li>
     </ul>
  </li>
</ul>

JavaScript

    $('#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){                  
                retrieveResults($(event.target));
            }
            //Toggle the lists if they show or not
            $(event.target).toggleClass('expanded');
            $(event.target).children('ul').slideToggle('medium');
            event.stopPropagation();
            $('.detailLI').unbind("click");
        })
        .addClass('collapsed')
            .removeClass('expanded')
            .children('ul').hide();
4

2 回答 2

0

为什么不向复选框元素添加单击事件并将“event.stopPropagation”放在那里以停止冒泡?

于 2012-09-11T17:06:24.297 回答
0

使用 on() 和 off() 绑定/取消绑定事件。从 jQuery 1.7 开始,所有其他绑定/解除绑定的方法都已被弃用。

于 2012-09-11T16:55:11.170 回答