1. 第一种做法
首页在外层容器里面取一个名字为main,即ref="main",当bankSwitch为true的时候,弹窗出现
<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)
最后,在页面注销前,将点击事件给移除
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的时候,弹窗出现
<div class="selectedBorder" @click.stop> <div class="bankItem" v-if="bankSwitch == true"> 你好我是弹窗里面的内容部分 </div> </div>
所触发的事件如下:
首页,先在全局创建一个点击事件:bodyCloseMenus
事件作用:当弹窗出现的时候(self.bankSwitch == true),点击空白区域将弹窗关闭(self.bankSwitch = false)
最后,在页面注销前,将点击事件给移除
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); },
以上就是vue中实现点击空白区域关闭弹窗的两种方法的详细内容,更多关于vue 点击空白区域关闭弹窗的资料请关注华域联盟其它相关文章!
您可能感兴趣的文章:
- vue点击弹窗自动触发点击事件的解决办法(模拟场景)
- vue.js实现点击图标放大离开时缩小的代码
- Vue实现点击当前行变色
- vue3.0实现点击切换验证码(组件)及校验
- 详解vue中在父组件点击按钮触发子组件的事件
- Vue 防止短时间内连续点击后多次触发请求的操作
- vue实现动态给id赋值,点击事件获取当前点击的元素的id操作
- vue实现点击出现操作弹出框的示例
- vue用ant design中table表格,点击某行时触发的事件操作
- vue实现水波涟漪效果的点击反馈指令
本文由 华域联盟 原创撰写:华域联盟 » vue中实现点击空白区域关闭弹窗的两种方法
转载请保留出处和原文链接:https://www.cnhackhy.com/45640.htm