jquery如何实现点击空白处隐藏元素
我们在网站开发的时候经常会有点击空白处去隐藏已有的元素,DIV或者其他,本次教给大家如何用jquery实现这个特效的方法。
一款jQuery点击空白处隐藏弹出层网页特效,点击按钮弹出层、点击页面空白处弹出层消失JS代码。主要功能是点击按钮弹出层显示,然后通过点击页面任意位置都能关闭弹出层显示效果,主要是$(document).click的操作应用。演示Demo,效果源码:
CSS代码:
*{ padding:0; margin:0; } #btnShow{ margin:100pxauto0; width:90px; display:block; } #divTop{ border:2pxsolid#666666; position:absolute;display:none; width:400px; height:200px; color:#333; background:#efefef; padding-top:10px; text-align:center; font:16px/30px"微软雅黑"; margin-top:-105px; margin-left:-200px; left:50%; top:50%; }
JS代码:
$(function(){ $('#btnShow').click(function(event){ //取消事件冒泡 event.stopPropagation(); //按钮的toggle,如果div是可见的,点击按钮切换为隐藏的;如果是隐藏的,切换为可见的。 $('#divTop').toggle('slow'); returnfalse; }); //点击空白处隐藏弹出层,下面为滑动消失效果和淡出消失效果。 $(document).click(function(event){ var_con=$('#divTop');//设置目标区域 if(!_con.is(event.target)&&_con.has(event.target).length===0){//Mark1 //$('#divTop').slideUp('slow');//滑动消失 $('#divTop').hide(1000);//淡出消失 } }); })
HTML代码:
点击空白区域弹出层关闭!
经过测试,在移动端Iphone手机上点击页面空白处弹出层关闭失效,不支持document写法,解决方案:可以添加一个背景层作为页面空白对象处理。
点击空白处隐藏弹出层案例二:
点击空白处关闭弹出层 #box{width:300px;height:200px;border:1pxsolid#000;display:none;} .btn{color:red;} $(function(){ $(".btn").click(function(event){ vare=window.event||event; if(e.stopPropagation){ e.stopPropagation(); }else{ e.cancelBubble=true; } $("#box").show(); }); $("#box").click(function(event){ vare=window.event||event; if(e.stopPropagation){ e.stopPropagation(); }else{ e.cancelBubble=true; } }); document.onclick=function(){ $("#box").hide(); }; })
点击空白处关闭弹出层