事件冒泡,下拉框模拟消失

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>前台网页</title>
<meta http-equiv="Content-Type" content="text/html; charset=vp"/>
<meta name="keywords" content="" />
<meta name="description" content="" />
<style type="text/css">
.menu {
display: none;
background-color: #fff;
width: 100px;
}

.show {
display: block;
}
</style>
</head>
<body>
<button class="showBtn">显示菜单</button>
<!-- 菜单默认不显示 -->
<div class="menu">
<ul>
<li>菜单一</li>
<li>菜单二</li>
<li>菜单三</li>
</ul>
</div>
<script type="text/javascript">
//点击“显示菜单”按钮时,显示菜单,并阻止事件冒泡
document
.querySelector('.showBtn')
.addEventListener('click', function(e){
document.querySelector('.menu').classList.add('show');
e.stopPropagation();//关键在于阻止冒泡
}, false);

//点击“菜单”内部时,阻止事件冒泡。(这样点击内部时,菜单不会关闭)
document
.querySelector('.menu')
.addEventListener('click', function(e){
e.stopPropagation();
}, false);

//监听整个document的点击事件,如果能收到事件(说明点击源既不是“显示菜单”按钮,也不来自菜单内部),就可以放心关闭菜单了
document
.addEventListener('click', function(){
document.querySelector('.menu').classList.remove('show');
}, false);
</script>
</body>
</html>

posted @ 2018-04-23 21:08  小曦曦  阅读(98)  评论(0编辑  收藏  举报