vue如何实现点击目标区域之外可关闭目标区域
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章将为大家详细讲解有关vue如何实现点击目标区域之外可关闭目标区域,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。点击目标区域之外可关闭目标区域解决思路方法一1
千家信息网最后更新 2025年01月19日vue如何实现点击目标区域之外可关闭目标区域
这篇文章将为大家详细讲解有关vue如何实现点击目标区域之外可关闭目标区域,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
点击目标区域之外可关闭目标区域
解决思路
方法一
1、vue模块中的内容 -- class为myPanel的div是我们要处理的那个小组件。
2、定义点击事件 -- 直接在生命周期钩子函数mounted(dom挂载完成之后)中添加点击事件,通过判断目标元素的class名称可实现对应的效果
mounted(){ document.addEventListener('click', (e)=> { if (e.target.className != 'myPanel') { this.panelShow= false; } })}
方法二
1、vue模块中的内容 -- class为myPanel的div是我们要处理的那个小组件。其中,stop修饰符是用来阻止函数的传递,简单理解就是执行自身绑定的事件,不影响其他位置绑定的事件。此处clickPanel函数中可不做任何处理,单纯用来阻止点击事件传递到绑定在body上的click事件去。
2、通过watch监听panelShow的值,对应在body绑定点击事件/取消绑定的点击事件
watch: { panelShow(val) { if(val) { document.body.addEventListener('click', () => { this.panelShow = false; }) } else { document.body.removeEventListener('click', () => {}); } }}
注:也可以通过给body绑定一个点击事件,然后去判断点击的元素是否是需要隐藏掉的元素。
vue点击组件外部隐藏组件自身
在开发组件的时候,点击组件外部隐藏组件自身的这种情况很长见到,例如:时间选择框组件,下拉选件等。
示图:点击外层元素隐藏自定义车牌选择框
代码如图中所写
核心
1、最外层div中添加一个@click.stop(取消事件冒泡),可以不添加事件名。
2、在mounted给body添加一个点击事件,事件触发组件的隐藏。
document.body.addEventListener('click', () => { this.show = false; }, false);
关于"vue如何实现点击目标区域之外可关闭目标区域"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
事件
组件
目标
区域
元素
内容
函数
篇文章
外层
方法
更多
模块
处理
选择
不错
实用
可不
代码
位置
可以通过
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全师属于什么专业
股票软件开发定制
数据库比对电子表格
pc电脑查看苹果账号数据库
pubg吃鸡手游无法连接服务器
nosql数据库设计的技术
跨表格操作数据库
游戏服务器安全测试
查询数据库最大游标
应用软件开发行业的风险
为什么代理服务器老是自动打开
码链上海网络技术有限公司
网络安全乔治
广东大学网络安全态势中标
计算机网络技术可以做什么职位
怎么下载三星服务器的游戏
基于服务器AAA认证
服务器报错显示代码
互联网科技年度公关传播方案
天津数据库基础学习
贵阳市网络安全办公室
数据库比对电子表格
软件开发宣传的文案
女生真的适合学软件开发吗
怎么清空服务器硬盘
武汉深圳东塔网络安全培训
网络安全应急响应阶段有哪些
从事网络技术工作怎么样
安徽潮流软件开发价格监测中心
软件开发逻辑思维题