您的位置:首页 > Web前端 > JavaScript

JS-JQ-事件冒泡

2020-03-28 20:13 726 查看

一、冒泡的原理:

  子元素会触发父元素的事件

  自上而下的触发事件

二、解决方法:

  JS:

     IE:event.cancelBubble=true  

     FF:event.stopPropagation()

  JQ:

      ev.stopPropagation()

 

 

!!! - CSS

<style>
  .div1{width:800px;height:500px;padding:100px;box-sizing: border-box;background:rosybrown;}
  .div2{width:500px;height:200px;background:#269ABC;}
</style>

 

!!! - HTML

<div class="div1">
  <div class="div2"></div>
</div>

 

!!! - JavaScript

window.οnlοad=function()
{
  var div1=document.getElementsByClassName('div1')[0];
  var div2=document.getElementsByClassName('div2')[0];
  div1.οnclick=function()
  {
    alert('我是DIV1');
  }
  div2.οnclick=function(ev)
  {
    var oEvent=ev||event;
    if(ev.cancelBubble)
    {
      oEvent.cancelBubble=true;
    }
    else
    {
      oEvent.stopPropagation();
    }
    alert('我是DIV2');
  }
}

 

!!! - JQuery

$(function(){
  $('.div1').click(function(){
    alert('我是DIV1');
  });
  $('.div2').click(function(ev){
    alert('我是DIV2');
    ev.stopPropagation();
  });
})

转载于:https://www.cnblogs.com/xiaoyangtian/p/7922118.html

  • 点赞
  • 收藏
  • 分享
  • 文章举报
anhu8321 发布了0 篇原创文章 · 获赞 0 · 访问量 177 私信 关注
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: