dom显隐(点击指定dom外位置,隐藏dom)

html

<span @click='CompilationChange'>显示隐藏dom</span>


//主要内容 v-show="zhxx_flag" id='zjssID'
<div v-show="zhxx_flag" id='zjssID'>
        <div>显隐内容</div>
</div>

js

//控制dom显隐

//显隐标识zhxx_flag 
const zhxx_flag = ref(false);

function checkClickOutside($event) {
    //获取dom
  let dom=document.querySelector('#zjssID')
//dom.contains($event.target)判断点击位置是否在dom内

  console.log("------event--",dom.contains($event.target))

  // 不在dom内,将dom隐藏,并删除事件监听
    if (!dom.contains($event.target)) {
      zhxx_flag.value = false;
      document.removeEventListener("click", checkClickOutside);
    }
}


//初始的控制dom显示,并创建出点击监听事件

const CompilationChange = (event) => {
  event.stopPropagation(); // 阻止事件冒泡
  zhxx_flag.value = true;
  if (zhxx_flag.value) {
    document.addEventListener("click", checkClickOutside);
  } else {
    document.removeEventListener("click", checkClickOutside);
  }
};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值