js点击目标区域以外,隐藏目标

背景:点击 #modelTransparent 展示 #transparentControl
需求:点击空白区域隐藏 #transparentControl

目标区域: #transparentControl

//显示
$("#modelTransparent").click(function() {
    $("#transparentControl").css("display","block");
});

//隐藏
$(document).click(function(e){
    var tc = $("#transparentControl");
    if(tc.css("display") === "block"){
       var mt = $("#modelTransparent");
       if(!mt.is(e.target) && mt.has(e.target).length === 0){
          if(!tc.is(e.target) && tc.has(e.target).length === 0){
            tc.css("display","none");
          }
       }
    }
});

第一层判断是为了避免显示目标时,目标一闪而过的情况:
if(!mt.is(e.target) && mt.has(e.target).length === 0)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值