Vue怎么实现点击当前元素以外的地方隐藏当前元素-成都快上网建站

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

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

成都创新互联自2013年起,先为临城等服务建站,临城等地企业,进行企业商务咨询服务。为临城企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

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"

方法三: