我有一个简单的设置,一个表格,其单元格内有复选框。我有两个事件,一个事件响应单击复选框,另一个事件响应单击“tr”元素。当我单击复选框时,我不希望触发表行事件。我试过了event.stopPropagation()
and return false;
没有任何运气。这是一个片段:
$("tr").click(function() {
alert("tr clicked");
});
$("input[type=checkbox]").change(function(event) {
event.stopPropagation();
alert("checkbox clicked");
});
像这样的东西:
<tr>
<td><input type="checkbox" id="something" name="something" /></td>
</tr>
如果更改事件触发,则单击事件也会触发。有关如何阻止的任何线索tr
如果复选框在以下范围内发生更改,则触发单击事件td
的元素tr
?
我推荐这个:
$( '#theTable' ).delegate( 'tr', 'click', function ( e ) {
if ( $( e.target ).is( 'input:checkbox' ) ) {
alert( 'checkbox clicked' );
} else {
alert( 'tr clicked' );
}
});
所以你有了only one单击整个表的处理程序。
顺便说一句,您不必将所有代码都放在这个处理程序中。您可以为每个操作设置单独的功能(单击复选框 VS 单击行),然后...
$( '#theTable' ).delegate( 'tr', 'click', function ( e ) {
if ( $( e.target ).is( 'input:checkbox' ) ) {
checkboxClicked( e );
} else {
rowClicked( e );
}
});
function checkboxClicked ( e ) {
// process event
}
function rowClicked ( e ) {
// process event
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)