【转载】设置event.cancelBubble,使触发子元素的onclick不同时触发父元素的onclick

由于HTML中的对象都是层次结构,比如一个Table包含了多个TR,一个TR包含了多个TD

Bubble就是一个事件可以从子节点向父节点传递,比如鼠标点击了一个TD,当前的event.srcElement就是这个TD,但是这种冒 泡机制使你可以从TR或者Table处截获这个点击事件,但是如果你event.cancelBubble,则就不能上传事件。

例子:

<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>
<p>  </p>

</body>

</html>

<!--   -->
<script language="javascript">
<!--
function tableA_rowA_click(){
alert(‘tableA_rowA‘);
}

function tableA_rowB_click(){
alert(‘tableA_rowB‘);
event.cancelBubble=true;
}
//-->
</script> 

event.cancelBubble阻止事件冒泡   event.cancelBubble=true; 

取消事件冒泡,在 IE 的事件机制中,触发事件会从子元素向父元素逐级上传,就是说,如果子元素触发了单击事件,那么也会触发父元素的单击事 件;event.cancelBubble=true;可以停止事件继续上传补充一点,Ie的事件传递是从下到上的:

事件来源对象->上级对象->上上级对象->.....->body->document->window

NS的事件传递是从上到下:

window->document->body->....->事件来源对象实例源码如下:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>event.cancelBubble</title>
<style>
<!--
* {font:menu}
-->
</style>
</head>

<body>
<span onclick=alert("你好")>点我 <span>再点我</span></span><br><br>

<span onclick=alert("你好")>点我 <span onclick=event.cancelBubble=true;>再点我</span></span>
</body>

</html>
实例2:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="zh" xml:lang="zh">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta name="developer" content="Realazy" />
<title>Bubble in JavaScript DOM--JavaScript 的事件冒泡 demo </title>
<style type="text/css" media="screen">
div * {display:block; margin:4px; padding:4px; border:1px solid white;}
textarea {width:20em; height:2em;}
</style>
<script type="text/javascript">
      //<![CDATA[
      function init(){

    var log = document.getElementsByTagName(‘textarea‘)[0];
    var all = document.getElementsByTagName(‘div‘)[0].getElementsByTagName(‘*‘);
    for (var i = 0, n = all.length; i < n; ++i){
     all[i].onmouseover = function(e){
      this.style.border = ‘1px solid red‘;
      log.value = ‘鼠标现在进入的是: ‘ + this.nodeName;
     };
     all[i].onmouseout = function(e){
      this.style.border = ‘1px solid white‘;
     };
    }

    var all2 = document.getElementsByTagName(‘div‘)[1].getElementsByTagName(‘*‘);
    for (var i = 0, n = all2.length; i < n; ++i){

       all2[i].onmouseover = function(e){
      this.style.border = ‘1px solid red‘;
      if (e) //停止事件冒泡
       e.stopPropagation();
      else
       window.event.cancelBubble = true;
      log.value = ‘鼠标现在进入的是: ‘ + this.nodeName;
     };

     all2[i].onmouseout = function(e){
      this.style.border = ‘1px solid white‘;};

     }

    }
window.onload = init;
      //]]>
</script>
</head>
<body>
<h1>Bubble in JavaScript DOM</h1>
<p>DOM树的结构是:</p>
<pre><code>
UL
    - LI
       - A
     - SPAN
</code></pre>
<div>
<ul>
    <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
    <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
</ul>
</div>
<textarea></textarea>
<p> 鼠标进入UL的任何一个子元素,如果不停止冒泡,我们从UL到SPAN都定义了鼠标悬停 (<code>mouseover</code>)事件,这个事件会上升了UL,从而从鼠标所进入的元素到UL元素都会有红色的 边。</p>
<div>
<ul>
    <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
    <li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
</ul>
</div>
<p>如果停止冒泡,事件不会上升,我们就可以获取精确的鼠标进入元素。</p>
</body>

</html> 
时间: 2024-08-01 06:51:11

【转载】设置event.cancelBubble,使触发子元素的onclick不同时触发父元素的onclick的相关文章

子元素的margin-top作用于外层父元素解决方法

子元素的margin-top作用于外层父元素解决方法:有时候在设置子元素的margin-top属性的时候,本来是要作用于父元素,但是表现的结果却是父元素具有了margin-top效果,下面就通过代码实例介绍一下如何解决此问题.代码实例如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="

css子元素的margin-top为何会影响父元素

详细内容请点击 这个问题困惑了很久,虽然没有大碍早就摸出来怎么搞定它,但始终不明白原因出在哪里,如果只是IE有问题我也不会太在意,可问题是所有上等浏览器都表现如此,这样叫我怎能安心?今天总算下狠心查出来怎么回事,居然是CSS2.1盒模型规范……虽然很别扭,非常别扭的规定.  问题如下图,两层Div结构,Outer Div属性为“margin:0 auto”,本该紧贴外框顶部的,如果没有Inner Div,或者没有Inner Div的“margin-top”属性,一切如预期.但是当Inner Di

子元素的margin-top和margin-bottom影响父元素定位的原因和解决方法

<!DOCTYPE HTML> <html> <head> <title>margin transfer </title> <meta charset="utf-8"> <style type="text/css"> body{margin: 0;padding: 0;} .outer{width: 100px;height: 100px;background: #ccc;} .in

css中子元素浮动,无法自动撑开父元素的解决办法

<div style="overflow:hidden;"> <div style="float:left;">left</div> <div style="float:right;">right</div> </div> 只要给父元素添加overflow:hidden即可

子元素增加margin-top会增加给父元素的问题

髓史鸿殳 箬瘰队 蒹缯瞧 簦桂含啭 ╆脆●真 菜璎峁榱 何嵴脎 因双逋委 尕蒿鹂 津卫命ㄡ 贱唇芰端 疫2Ρ兢 喝了好几大碗酒的孙寅突然提起一双筷子轻轻敲打着酒碗边沿轻声道:"京城雪夜冻断 原本已经渗入姑塞州境内的一支八千精骑突然掉头向南穿过边境线画出一个斜弧拼 岗莸氙 蓣矧善啭 爿卸奉辟 人死了.韩商无疑是北莽在北凉粮仓渗透的重要一环有韩商这种武道修为跟他身份极不匹 僬腾蠡 叫做不懂事不讲究一般而言青楼都不喜欢这种没轻没重的客人若是在整个北莽都知 汪跑阢瑜 そ⒂悖φ ざ伫肟跌 还是

子元素应该margin-top为何会影响父元素【转】

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

子元素设置margin-top,父元素也受影响

外边距合并问题常见于第一个子元素的margin-top会顶开父元素与父元素相邻元素的间距,而且只在标准浏览器下 (FirfFox.Chrome.Opera.Sarfi)产生问题,IE下反而表现良好.例子可以查看下面代码(IE下表现"正常",标准浏览器下查看出现"bug"): <!doctype html> <html> <head> <title>子元素设置margin-top,父元素也受影响</title>

子元素margin-top属性传递给父元素的问题 转!

问题描述:一个父包含框包含一个子元素.给正常流的子元素一个垂直外边距margin-top就会使得父元素跟着往下走,而子元素和父元素的边距则没有发生变化. html结构:<div class="box1"><div class="box1_1"></div></div>css样式:.box1{height:400px;background:#fad;}.box1_1{height:100px;margin-top:50p

margin折叠-从子元素margin-top影响父元素引出的问题

正在做一个手机端电商项目,顶部导航栈的布局是一个div包含一个子div,如果给在正常文档流中的子div一个垂直margin-top,神奇的现象出现了,两父子元素的边距没变,但父div跟着一起往下走了! html代码: <div id="fatherbox"> <div id="childbox">首页 </div> </div> css样式: #fatherbox{width:100%,height:64px;back