技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> JavaScript --> jQuery事件的冒泡过程

jQuery事件的冒泡过程

浏览:2917次  出处信息

严格来说,事件在触发后被分为两个阶段,一个是捕获(Capture),另一个则是冒泡(Bubbling)。不过大多数浏览器不是都支持捕获阶段,jQuery也不支持,因此在事件触发后,往往执行冒泡过程。冒泡的实质就是事件执行中的顺序,通过以下例子来解释。

<!DOCTYPE HTML>
<html>
<head>
    <meta content=\"charset=utf-8\">
    <title>事件中的冒泡现象</title>
    <script type=\"text/javascript\" src=\"jquery-1.4.2.min.js\"> </script>
    <script type=\"text/javascript\">
  $(function(){
   $(\"#hr_three\").click(function() { alert(\"最里层\"); });
   $(\"#divTwo\").click(function() { alert(\"中间层\"); });
   $(\"#divOne\").click(function() { alert(\"最外层\"); });
  });
 </script>
</head>
<body>
 <div id=\"divOne\">
         <div id=\"divTwo\">
             <a id=\"hr_three\"  href= \"http://tinyliu.info\">点击我</a>
         </div>
    </div>
</body>
</html>

该页面分为三层,分别是divOne、divTwo和hr_three,他们都有各自的click事件。运行页面时点击“点击我”,会依次弹出“最里层”、“中间层”、“最外层”,然后链接到tinyliu.info。这就是事件的冒泡过程,虽然只点击了一次链接,但链接外围的divTwo的事件也被触发,同时divTwo的外围divOne的事件也随之被触发,一共执行了三次alert,从里到外。整个事件波及的过程就像水泡一样往外冒,故称为冒泡过程。

在实际需要中,很多时候并不希望事件的冒泡现象发生,jQuery中可通过两种方法来阻止冒泡过程的发生。

1. event.stopPropagation();

$(function(){
 $(\"#hr_three\").click(function() {
  alert(\"最里层\");
  event.stopPropagation();
 });
});

2. return false;

$(function(){
 $(\"#hr_three\").click(function() {
  alert(\"最里层\");
  return false;
 });
});

他们的区别在于stopPropagation只阻止冒泡过程(即只触发一次alert),不会阻止事件的默认行为(跳转到tinyliu.info);而return false不仅会阻止冒泡过程,也会组织事件的默认行为,alert完成后不会跳转到tinyliu.info。与此相关的还有一个preventDefault函数,此函数与return false相反,它不会阻止冒泡过程,但会阻止默认行为。

建议继续学习:

  1. JQuery实现Excel表格呈现    (阅读:46516)
  2. 分享一个JQUERY颜色选择插件    (阅读:12629)
  3. jQuery插件---轻量级的弹出窗口wBox.    (阅读:9682)
  4. 10个强大的Ajax jQuery文件上传程序    (阅读:7750)
  5. jQuery的data()方法    (阅读:7573)
  6. jQuery性能优化指南    (阅读:7302)
  7. jQuery Color Animations颜色动画插件    (阅读:7069)
  8. 精于图片处理的10款jQuery插件    (阅读:6203)
  9. 深入浅出交换类排序算法(冒泡排序,快速排序)    (阅读:5970)
  10. jQuery中getJSON跨域原理详解    (阅读:5612)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1