jQuery点击自身以外区域关闭弹出层功能 jQuery实现点击自身以外区域关闭弹出层功能完整示例【改进版】
夏天的一朵云 人气:0本文实例讲述了jQuery实现点击自身以外区域关闭弹出层功能。分享给大家供大家参考,具体如下:
原理参考前面一篇《JS使用遮罩实现点击某区域以外时弹窗的弹出与关闭功能》,小编顺便对原文区域外点击bug进行了修改,具体代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>www.qb5200.com jQuery点击关闭弹出层</title> <style> .area{width:100%;height:100%;position:fixed;z-index:1;} .hide{display:none;} .con{width:400px; height:200px; background-color: #F6F4F0;position:fixed;z-index:2;} </style> </head> <body> <div class="area hide"></div> <div class="down">click</div> <div class="con hide">show-area</div> <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script> <script type="text/javascript"> $(document).ready(function() { $("div.down").click(function(e) { e.stopPropagation(); $("div.con").removeClass("hide"); $("div.area").removeClass("hide"); }); $(".area").click(function() { if (!$("div.con").hasClass("hide")) { $("div.con").addClass("hide"); $("div.area").addClass("hide"); } }); }); </script> </body> </html>
运行该代码后,点击页面上的click可弹出一个弹出层,再点击弹出层外的空白区域即可关闭弹出层。
使用在线HTML/CSS/JavaScript代码运行工具:http://tools.softyun.net/code/HtmlJsRun测试运行效果如下:
希望本文所述对大家jQuery程序设计有所帮助。
加载全部内容