jQuery 单击停止传播

标签 jquery

我有一个简单的设置,一个表格,其单元格内有复选框。我有两个事件,一个事件响应单击复选框,另一个事件响应单击“tr”元素。当我单击复选框时,我不希望触发表行事件。我尝试了 event.stopPropagation()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>

如果更改事件触发,则单击事件也会触发。如果 trtd 元素中的复选框发生更改,是否有关于如何阻止 tr 点击事件触发的线索?

最佳答案

我推荐这个:

$( '#theTable' ).delegate( 'tr', 'click', function ( e ) {
    if ( $( e.target ).is( 'input:checkbox' ) ) { 
        alert( 'checkbox clicked' );
    } else {
        alert( 'tr clicked' );
    }        
});

因此,整个表格只有一个点击处理程序。

顺便说一句,您不必将所有代码都放在这个处理程序中。您可以为每个操作设置单独的函数(单击复选框 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
}

关于jQuery 单击停止传播,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7445199/

相关文章:

javascript - 网格和行高(jquery)

javascript - 从不同的 onchange 选择中获取 data-*

javascript - jquery javascript 问题

jQuery - 左键单击上下文菜单插件

javascript - 如何在 .click() 上取消绑定(bind)另一个 jQuery 函数?

php - Ajax 返回 null

javascript - 元素倒计时为空的类型错误

javascript - 魔术线宽度错误

javascript - 相当于在vanillajs中设置html和body height为window height

javascript - Firefox 抛出错误 - 正则表达式太复杂