点击其他区域隐藏弹出框效果

文章介绍了使用CSSfocus伪类和`:hover`以及JavaScript的contains函数来实现下拉框的动态隐藏与显示。通过input:focus状态控制弹出框显示,点击事件外区域或非下拉框内容时隐藏,确保用户体验和交互逻辑的流畅性。

一般下拉框或者选择框,持久展示时会给用户显示的隐藏方式,如点击事件后。也可以添加隐式的隐藏方式,如点击弹出框之外的区域。

CSS方法-focus伪类

当触发的元素是可以focus,以输入框为例。

  1. 可以将弹出框出现的时机设置在input:focus时,实现弹出的效果。当focus焦点转移的时候,实现隐藏效果。
  2. 在弹出框容器上添加hover事件,选择点击弹出框内容时不会隐藏,保证弹出框的点击事件可以触发。
  3. 当选中弹出框中的项时,input焦点转移,hover事件保证弹出框显示,可以触发点击事件。然后点鼠标移出弹出框区域后,弹出框hover失效,隐藏。
    缺点:
    隐藏可能不太流畅;触发的元素只能是能加focuse的元素
    <div class="selectorswarp">
      <label for="input">输入框:</label>
      <input type="text"  class="selectinput" id="input"/>
      <ul class="selectors" @click="clickli">
        <li>s1</li>
        <li>s2</li>
        <li>s3</li>
      </ul>
    </div>
.selectinput:focus{
  &+.selectors{
    display: block;
  }
}
.selectors{
  background-color: #42b983;
  height: auto;
  display: none;
  &:hover{
    display: block;
  }
}

或者使用:focus-within直接加在input元素的warp元素上.

JS方法-contains函数

Node.contains;
使用contains方法可以判断一个元素是否是判断元素的后代元素。可以在document上添加点击的监听事件,若事件的触发元素不是弹出框的后代元素,则隐藏弹出框。若是,则持续展示弹出框。

let listerSelectWarp = (e)=>{
  let target = e.target,
    selectorwrap = document.querySelector('.selectorswarp');
  showoptions.value = selectorwrap.contains(target);
  console.log('listerSelectWarp',selectorwrap.contains(target));
}
document.addEventListener('click',listerSelectWarp,);

注意:
当容易内部还有其他点击控制弹出框事件时,需要注意选择addEventListener的useCapture项,选择事件的触发方向。
缺点:
展示时需要比较明确事件的触发,比如点击事中添加类或变量控制。展示和隐藏需要控制同一样式或变量。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

晨灰ash2

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值