如何触发复选框上的更改或单击行以选择表格行?

时间:2012-02-23 23:35:39

标签: javascript jquery events checkbox html-table

我在第一列中有一个带复选框的表格。

可以通过(a)选中复选框或(b)单击行来选择行。应突出显示所选行。

我的问题是我可以让任何一个单独工作,但不能同时工作。这就是我所拥有的:

 // click on row      
 $('table tbody tr').click( function() {
    $(this).find( "th input:checkbox").trigger('change');
    // $(this).find( "th input:checkbox").trigger('click');
});

 // change listener
 $('.tr input:checkbox').live( "change", function () {
    console.log("change triggered");

  var row = $(this).closest('tr');

  if ( $(this).attr('checked') == "checked" ) {
          row.addClass( 'ui-btn-hover-c' ).removeClass( 'row_selected ui-btn-up-e' )
          } else {
              row.addClass('row_selected ui-btn-hover-e' ).removeClass( "ui-btn-up-c");
          }
  });   

我以为我只是将TR上的点击路由到复选框更改处理程序,因此只有一个地方检查选定的行并处理类添加/删除。

但是我无法让它发挥作用。以上不知何故创造了一个无限循环,我不知道如何让它正常工作。

1 个答案:

答案 0 :(得分:2)

如果一行上有一个侦听器,而行中的一个复选框上有另一个侦听器,那么当您单击该复选框时将触发这两个侦听器,除非您停止事件传播。即单击复选框也是单击tr。

通常你会使用event.stopPropagation();,但你不能在live()方法上使用它,因为事件已经传播。

http://api.jquery.com/event.stopPropagation/

在您的情况下,如果您可以使用live更改为使用click,则可以使用:

event.stopPropagation();

防止点击复选框触发表格行上的点击。