欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

js点击任意区域弹出层消失实现代码

程序员文章站 2022-08-14 08:38:27
本文实例为大家分享了js点击任意区域弹出层消失的具体代码,供大家参考,具体内容如下 采用jquery element.parents();判断点击区域是否在弹出层上面或者...

本文实例为大家分享了js点击任意区域弹出层消失的具体代码,供大家参考,具体内容如下

采用jquery element.parents();判断点击区域是否在弹出层上面或者在按钮上面,否则让弹出层消失。

完整代码

<!doctype html>
<html lang="en">
<head>
 <meta charset="utf-8">
 <title>title</title>
</head>
<body>

<pre>
 parent > child
 在给定的父元素下匹配所有的子元素
</pre>

<div class="help">
 <span class="bnt">我是弹出层</span>
 <ul id="list" class="foo">
  <li><a href="#">第1条记录</a></li>
  <li><a href="#">第2条记录</a></li>
  <li><a href="#">第3条记录</a></li>
  <li><a href="#">第4条记录</a></li>
 </ul>
</div>

<style>
 .bnt{
  width: 100px;height: 50px;background: #777;color: #fff;
  display: block;
  text-align: center;
  line-height: 50px;
  cursor: default;
 }
 .help ul{
  display: none;
  border: 1px solid #aaa;
 }
 a{display: block;padding: 10px;}
</style>

<script src="../jquery.js"></script>
<script>

 (function ($) {
  $('.bnt').click(function(){
   if($(this).hasclass('show')){
    $('.help ul').hide();
    $(this).removeclass('show')
    return ;
   }

   $('.help ul').show();
   $(this).addclass('show')

  })

  document.addeventlistener('click',function (e) {
   var parent=$(e.target).parents('.foo,.help');

   if(parent.length===0){
    console.log('不在弹层与按钮区')
    //操作此区域

    $('.help ul').hide();
    $('.bnt').removeclass('show');

   }else{
    console.log('按钮与弹层区')
   }
  })
 })(jquery);
</script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。