javascript写法 阻止事件冒泡
html代码
<!DOCTYPE html>
<html>
<head>
<script src="//code.jquery.com/jquery-2.1.1.min.js"></script>
<meta charset="utf-8">
<title>JS Bin</title>
</head>
<body>
<div id="wrapper" class="wrapper">
<button id="clickMe">点我</button>
<div id="popover" class="popover">
浮层
<input type="checkbox">
</div>
</div>
</body>
</html>
css代码
body{
border:1px solid red;
}
.wrapper{
position:relative;
display:inline-block;
}
.popover{
position:absolute;
top:0;
left:100%;
border:1px solid red;
white-space:nowrap;
padding:10px;
margin-left:10px;
display:none;
}
.popover::before{
position:absolute;
right:100%;
top:5px;
border:10px solid transparent;
border-right-color:purple;
content:'';
}
.popover::after{
position:absolute;
right:100%;
top:5px;
border:10px solid transparent;
border-right-color:white;
content:'';
}
clickMe.addEventListener('click',function(){
popover.style.display = 'block';
console.log('block');
});
wrapper.addEventListener('click',function(e){
e.stopPropagation();
});
document.addEventListener('click',function(){
popover.style.display="none";
console.log('none');
});
jQuery写法
css 和html同上
(popover).show();
});
//false等价于function(e)
{e.stopPropagation();
e.preventDefault();
}
$(wrapper).on('click',false);
当回调函数是false的时候 如果div里有checkbox 那么将无法选择 因为使用了阻止默认事件 怎么解决呢?那就阻止传播 如下:
那就证明如果在checkbox的父元素或者checkbox上添加了阻止默认事件 那么这个CheckBox就没办法选择
所以还是写成$(wrapper).on('click',function(e) {
e.stopPropagation();
});
只监听一次 打扫战场
(popover).show();
(popover).hide();
console.log('document');
});
});
$(wrapper).on('click',function(e){
e.stopPropagation();
});
(popover).show();
console.log('show');
setTimeout(function(){
console.log('添加click事件');
console.log('--------------');
$(document).one('click',function(){
console.log('我觉得不会执行');
console.log('hide');
$(popover).hide();
});
},0);
});
$(document).on('click',function(){
console.log('click走到了document');
});
①console.log("show");
②console.log("click执行到了document");
③ console.log('添加click事件');
console.log('--------------');
④再点击才会执行console.log('我觉得不会执行');
console.log('hide');
网友评论