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

2019-11-26,

本文实例为大家分享了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>

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

您可能感兴趣的文章:

  • JS使用遮罩实现点击某区域以外时弹窗的弹出与关闭功能示例
  • JavaScript实现点击按钮复制指定区域文本(推荐)
  • JS实现点击颜色块切换指定区域背景颜色的方法
  • js实现的点击div区域外隐藏div区域
  • js中点击空白区域时文本框与隐藏层的显示与影藏问题
  • js+html5实现canvas绘制椭圆形图案的方法
  • js+html5实现canvas绘制圆形图案的方法
  • JavaScript Canvas绘制圆形时钟效果
  • js Canvas实现圆形时钟教程
  • JavaScript实现的圆形浮动标签云效果实例
  • JS+HTML实现的圆形可点击区域示例【3种方法】

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

下载本文的Word格式文档,以方便收藏与打印。