JavaScript--vue--点击空白区域关闭弹窗的几种方式

判断点击事件发生在某个区域外的条件:
1.点击事件的对象不是目标区域本身
2.事件对象同时也不是目标区域的子元素

1.jQuery方式

$(document).mouseup(function(e){
	var 自定义名字=$('目标对象') //设置目标区域
	if(!自定义名字.is(e.target)&&自定义名字.has(e.target).length===0){
		//执行关弹窗的代码
	}
})

2.JavaScript方式

var 自定义名字= document.getElementById('目标对象'); 

// 点击整个界面关闭弹窗 
document.onclick = function()  {
    div.style.display = "none";  
}  
   
// 阻止点击弹窗时关闭弹窗
自定义名字.onclick = function()  {
    return false;  
}

3.vue方式

document.addEventListener('mouseup',(e)=>{
	var 自定义名字=document.querySelector('目标对象') //选择返回的第一个出现的元素
	if(自定义名字){
		if(!自定义名字.contains(event.target)){ //判断某个元素不是目标元素的子元素 即目标元素以外的区域
			this.绑定的控制弹窗的属性=false
		}
	}	
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值