vue,点击除组件外的元素,自动关闭组件或元素

页面中,设定模板的ref值 :

<div class="pop-box" ref="userRef" >
    <span class="pop-close iconfont icon-close" @click="hidePop"></span>
    
    <keep-alive>
      <component :is="currentComponent" @changeView="changeView" />
    </keep-alive>
  </div>

在该组件的钩子函数中调用点击事件:

mounted(){
    document.addEventListener('click',this.outClick)
  },

方法调用 :

// 点击外部收起下拉选框
    outClick(e){
      let userRef= this.$refs.userRef;
    //user-btn 与 iconfont icon-renwu  这两个点击使组件弹出的按钮元素
      if(e.target.className=='user-btn' || e.target.className=="iconfont icon-renwu"){
        return;
      }
      try{
        if(userRef && !userRef.contains(e.target) && this.showUser ){
         this.showUser =false
      }
      }catch(err){}
      
    },

同时,在该弹出组件里面的所有点击事件,都需要使用
@click.stop ="funcName"

文章用户记录学习开发vue的记录~
错误及不足之处请指教~
加油!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值