标签:lex == 适应 bind 节点 code 否则 点击其他 one
在编写页面的时候,我们经常使用到弹出层。对于弹出层,原本的意义就是增加与用户的交互,提升用户的好感度。如果弹出层都没有较好的体验,那何谈通过交互来提升好感。。。
首先提出几个弹出层的注意点:
今天,主要说说点击其他区域隐藏弹出层。笔者被这个效果折磨了很久,几乎每次实现这个效果都要查一遍资料,一次次尝试才能达到想要的效果。如此麻烦,皆是因为对事件冒泡的理解不够已经错误处理。
什么是事件冒泡?为什么要使用它?
事件冒泡:由最具体的元素接收(当前节点),然后逐级向上传播至最不具体的元素的节点(document);
在实现点击其他区域隐藏弹出层时,需要对document绑定点击事件,而事件冒泡会使点击其它节点时仍然触发该事件,从而造成事件冲突,导致该显示弹出层时显示不出,不该隐藏时却又隐藏了弹出层。
<style type="text/css">
.layer-container{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.5);
display: flex;
justify-content; center;
align-items: center;
display: none;
}
.layer-main{
width: 75%;
padding: 20px;
max-width: 400px;
}
</style>
<body>
<button>显示弹出层</button>
<div class="layer-container">
<div class="layer-main">
<div class="layer-header"></div>
<div class="layer-content"></div>
<div class="layer-footer">
<div class="layer-button">确认</div>
</div>
</div>
</div>
<script>
//点击按钮,显示弹出层
$("button").bind("click", function(){
$(".layer-container").css("display", "flex");
event.stopPropagation();//==========阻止冒泡1
})
//点击其他区域,隐藏弹出层
$(document).bind("click", function(){
$(".layer-container").css("display", "none");
})
//点击弹出层内确认按钮
$(".layer-button").bind("click", function(){
console.log("点击了确认按钮")
})
//给弹出层绑定点击事件,阻止冒泡
$(".layer-main").bind("click", function(){
event.stopPropagation();//==========阻止冒泡2
})
</script>
</body>
说明:
其实,还可以通过事件的目标(event.target)来识别当前点击的节点,从而进行接下来的操作,比如对指定的节点的特殊操作
==>>除指定区域外点击任何区域都隐藏div
$(‘body‘).click(function(e) {
var target = $(e.target);
// 如果#layer或者#btn下面还有子元素,可使用
// !target.is(‘#btn *‘) && !target.is(‘#layer *‘)
if(!target.is(‘#btn‘) && !target.is(‘#layer‘)) {
if ( $(‘#layer‘).is(‘:visible‘) ) {
$(‘#layer‘).hide();
}
}
});
$(‘body‘).click(function(e) {
if(e.target.id != ‘btn‘ && e.target.id != ‘overlay‘)
if ( $(‘#layer‘).is(‘:visible‘) ) {
$(‘#layer‘).hide();
}
})
拜拜!
标签:lex == 适应 bind 节点 code 否则 点击其他 one
原文地址:https://www.cnblogs.com/nangezi/p/9157112.html