JS技术

javascript 事件冒泡

字号+ 作者: 来源:    2014-11-17 20:00 我要评论( )

javascript 事件冒泡,阅读javascript 事件冒泡,Html代码 !DOCTYPE html PUBLIC

Html代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"  
 ""> 
<html xmlns="" 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</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>

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • 老生常谈,JavaScript闭包中的this对象

    老生常谈,JavaScript闭包中的this对象

    2016-02-26 10:21

  • 学习JavaScript之this,call,apply

    学习JavaScript之this,call,apply

    2016-01-28 20:45

  • JavaScript复习笔记--字符串

    JavaScript复习笔记--字符串

    2016-01-27 17:16

  • WEB前端教程-JavaScript里的类和继承

    WEB前端教程-JavaScript里的类和继承

    2016-01-21 15:28

网友点评