javascript 事件冒泡
作者:Eve Cole
更新時間:2009-06-11 16:22:17
html程式碼
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 過渡//EN"
「 http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd 」 >
<html xmlns=" http://www.w3.org/1999/xhtml " lang="zh" xml:lang="zh">
<頭>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta name="開發人員" content="Realazy" />
<title>JavaScript DOM 中的氣泡</title>
<style type="text/css" media="screen">
div * {顯示:區塊;邊距:4px;內邊距:4px;邊框:1px 純白色;}
文字區域{寬度:20em;高度:2em;}
</風格>
<腳本類型=“文字/javascript”>
//<![CDATA[
函數初始化(){
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 = 函數(e){
this.style.border = '1px 純紅色';
log.value = '滑鼠現在進入的是: ' + this.nodeName;
};
all[i].onmouseout = 函數(e){
this.style.border = '1px 純白色';
};
}
var all2 = document.getElementsByTagName('div')[1].getElementsByTagName('*');
for (var i = 0, n = all2.length; i < n; ++i){
all2[i].onmouseover = 函數(e){
this.style.border = '1px 純紅色';
if (e) //停止事件冒泡
e.stopPropagation();
別的
window.event.cancelBubble = true;
log.value = '滑鼠現在進入的是: ' + this.nodeName;
};
all2[i].onmouseout = 函數(e){
this.style.border = '1px 純白色';
};
}
}
視窗.onload = init;
//]]>
</腳本>
</頭>
<正文>
<h1>JavaScript DOM 中的氣泡</h1>
<p>DOM樹的結構是:</p>
<前><程式碼>
UL
-李
- A
- 跨度
</code></pre>
<div>
<ul>
<li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
<li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
</ul>
</div>
<文字區域></文字區域>
<p>滑鼠進入UL的任何一個子元素,如果不停止冒泡,我們從UL到SPAN都定義了滑鼠懸停(<code>mouseover</code>)事件,這個事件會上升了UL,從而從滑鼠所進入的元素到UL元素都會有紅色的邊。
<div>
<ul>
<li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
<li><a href="#"><span>Bubbllllllllllllllle</span></a></li>
</ul>
</div>
<p>如果停止冒泡,事件不會上升,我們就可以取得精確的滑鼠進入元素。
</正文>
</html>