vue中实现点击空白区域关闭弹窗的两种方法
1.第一种做法
首页在外层容器里面取一个名字为main,即ref="main",当bankSwitch为true的时候,弹窗出现
你好我是弹窗里面的内容部分
所触发的事件如下:
首页,先在全局创建一个点击事件:bodyCloseMenus
事件作用:当点击main容器的时候(this.refs.main&&!this.refs.main.contains(e.target)),并且弹窗出现的时候(self.bankSwitch==true),点击空白区域将弹窗关闭(self.bankSwitch=false)
最后,在页面注销前,将点击事件给移除
mounted(){
document.addEventListener("click",this.bodyCloseMenus);
},
methods:{
bodyCloseMenus(e){
letself=this;
if(this.$refs.main&&!this.$refs.main.contains(e.target)){
if(self.bankSwitch==true){
self.bankSwitch=false;
}
}
},
beforeDestroy(){
document.removeEventListener("click",this.bodyCloseMenus);
},
2.第二种做法
首页在外层容器里面定义一个阻止冒泡事件,即@click.stop,当bankSwitch为true的时候,弹窗出现
你好我是弹窗里面的内容部分