1. 第一种做法
首页在外层容器里面取一个名字为main,即ref="main",当bankSwitch为true的时候,弹窗出现
1 2 3 4 5 |
< div class = "selectedBorder" ref = "main" >
< div class = "bankItem" v-if = "bankSwitch == true" >
你好我是弹窗里面的内容部分
</ div >
</ div >
|
所触发的事件如下:
首页,先在全局创建一个点击事件处理函数:bodyCloseMenus
事件作用:当点击main容器的时候(this.refs.main && !this.refs.main.contains(e.target)),并且弹窗出现的时候(self.bankSwitch == true),点击空白区域将弹窗关闭(self.bankSwitch = false)
最后,在页面注销前,将点击事件给移除
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
mounted() {
document.addEventListener( "click" , this .bodyCloseMenus);
},
methods:{
bodyCloseMenus(e) {
let self = 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的时候,弹窗出现
1 2 3 4 5 |
< div class = "selectedBorder" @click.stop>
< div class = "bankItem" v-if = "bankSwitch == true" >
你好我是弹窗里面的内容部分
</ div >
</ div >
|
所触发的事件如下:
首页,先在全局创建一个点击事件:bodyCloseMenus
事件作用:当弹窗出现的时候(self.bankSwitch == true),点击空白区域将弹窗关闭(self.bankSwitch = false)
最后,在页面注销前,将点击事件给移除
1 2 3 4 5 6 7 8 9 10 11 12 13 |
mounted() {
document.addEventListener( "click" , this .bodyCloseMenus);
},
methods:{
bodyCloseMenus(e) {
let self = this ;
if (self.bankSwitch == true ){
self.bankSwitch = false ;
}
},
beforeDestroy() {
document.removeEventListener( "click" , this .bodyCloseMenus);
},
|
原文链接:https://juejin.cn/post/6911863086487961607
标签:vue,bankSwitch,self,点击,bodyCloseMenus,main,true,弹窗 From: https://www.cnblogs.com/balashuijiao/p/16777885.html