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

时间:2016-12-27    点击:77   

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

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

JavaScript实现经典排序算法之插入排序
JavaScript实现经典排序算法之选择排序
JavaScript实现经典排序算法之冒泡排序
获取当前月(季度/年)的最后一天(set相关操作及应用)
基于jQuery实现顶部导航栏功能
> 返回     
地址:上海市普陀区胶州路941号长久商务中心 电话: QQ:
© Copyright 2012 上海网络 Product All Rights Reserved