Vue怎么实现点击当前元素以外的地方隐藏当前元素-创新互联

小编给大家分享一下Vue怎么实现点击当前元素以外的地方隐藏当前元素,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

创新互联建站是一家专业的成都网站建设公司,我们专注成都网站建设、成都网站设计、网络营销、企业网站建设,买友情链接广告投放平台为企业客户提供一站式建站解决方案,能带给客户新的互联网理念。从网站结构的规划UI设计到用户体验提高,创新互联力求做到尽善尽美。

1. 绑定元素

Vue怎么实现点击当前元素以外的地方隐藏当前元素

2. mounted生命周期

Vue怎么实现点击当前元素以外的地方隐藏当前元素

3. 实现思路

  • 页面挂载完后,监听全局点击事件

  • 获取当前点击的元素,根据需求获取当前元素本身的属性

  • 判断当前点击元素与要隐藏的元素是否相同

  • 当前点击元素与要隐藏的元素不相同则隐藏

4. 最终效果

Vue怎么实现点击当前元素以外的地方隐藏当前元素

接着看下vue实现点击目标元素外页面的其他地方隐藏弹窗

方法:

步骤1:给页面最外出的元素div加点击事件:@click=“popShow = false”

步骤2:给点击目标元素加点击事件:@click=“popShow = true”

备注:popShow 为控制弹窗显示与隐藏的标志。

PS:下面看下vue实现点击其他地方隐藏div

方法一:  

  通过监听事件

document.addEventListener('click',function(e){
    if(e.target.className!='usermessage'){
     that.userClick=false;
    }
})

方法二(比较好):

  给最外层的div加个点击事件 @click="userClick=false"

  给点击的元素上面加上:@click.stop="userClick=!userClick"

方法三: