父级元素点击,遮盖了子元素的点击

本文通过两个具体场景展示了如何在HTML与JavaScript中有效利用event.cancelBubble属性来阻止事件冒泡,以及如何解决因父元素事件处理导致子元素事件被覆盖的问题。

1.场景1:组织消息上传,点击父元素,禁止子元素的事件执行

event.cancelBubble=true 的使用

<html>
<body>
<table border="1" width="26%" id="tableA" onclick="alert('tableA')">
<tr onclick="tableA_rowA_click()">
   <td width="106">一般</td>
</tr>
<tr onclick="tableA_rowB_click()">
   <td width="106">阻止消息上传</td>
</tr>
</table>

</body>
</html>
<script language="javascript">
<!--
function tableA_rowA_click(){
  alert('1');
  //结果,alert 出:
  tableA 和 1
  */

}
function tableA_rowB_click(){   
  alert(
'2');   
  event.cancelBubble
=true;
  //结果,alert 出:
  tableA

  */
}
//-->
</script>

 如图 

$('.orderDetail-table input').on('click',function(e){
e.stopPropagation();
});

2.场景2,tr加了点击事件,覆盖了checkbox的点击选中,

解决方式:在需要加事件的被覆子元素上加事件

<tr class="onhover" onclick="toggleCheckedBox(@p.id);">
<td><input id="checkedbox_@p.id" type="checkbox" name="payid" value="@p.id" onclick="toggleCheckedBox(@p.id);"></td>
<td>222</td>
<td>2222</td>
</tr>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值