例如:
百度,google上面的链接,点击链接之后,出现下拉菜单,鼠标离开不消失,鼠标点击菜单以外的地方,才会使下拉菜单消失。这样的功能怎么实现?谁能给个类似的代码参考一下?
简单方法,控制事件冒泡:
<button class="showBtn">显示菜单</button>
<!-- 菜单默认不显示 -->
<div class="menu">
<ul>
<li>菜单一</li>
<li>菜单二</li>
<li>菜单三</li>
</ul>
</div>
//点击“显示菜单”按钮时,显示菜单,并阻止事件冒泡
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);
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。