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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」