博客
关于我
关于点击弹框外部区域弹框关闭的交互处理
阅读量:461 次
发布时间:2019-03-06

本文共 1241 字,大约阅读时间需要 4 分钟。

常见需求场景

在前端开发中,处理交互时常遇到以下场景:点击按钮后,出现一个弹框,用户点击外部区域时,弹框关闭。这种需求虽然简单,但实现起来需要仔细考虑细节。

解决方法

解决这个问题的思路是:通过给弹框的父级div添加特定的类名,并在document上绑定点击事件,来判断点击的区域是否是弹框之外的区域。

具体实现步骤如下:

  • 为弹框的父级div添加类名(例如:box-contentbox-filterbox-list等)。
  • 在document上绑定点击事件,当发生点击时:
    • 获取当前点击元素的类名,向上查找其所有父级元素的类名。
    • 如果父级类名中不包含我们预定义的弹框相关类名,则表示点击的是外部区域,此时关闭弹框。
    • 如果包含,则表示点击的是弹框内部,不需要处理。
  • 代码实现

    以下是具体的代码实现方式:

    document.addEventListener('click', e => {    if (this.boxShow) {        this.closeBox(e);    }});closeBox(e) {    e.stopPropagation(); // 阻止事件冒泡    const parentNames = this.getParentsClassName(e.target);        // 判断是否点击了外部区域    if (!parentNames.includes('box-content') &&         !parentNames.includes('box-filter') &&         !parentNames.includes('box-list')) {        this.boxShow = false;    }}getParentsClassName(el) {    let p = el.parentNode;    const parents = new Set();    parents.add(el.className);        while (p && p.tagName !== 'BODY') {        parents.add(p.className);        p = p.parentNode;    }        return Array.from(parents);}

    以上代码实现的逻辑是:

    • 当document发生点击事件时,检查是否正在显示弹框(this.boxShow)。
    • 调用closeBox方法处理关闭逻辑。
    • closeBox方法通过getParentsClassName获取当前元素及其父级元素的类名集合。
    • 如果类名集合中不包含预定义的弹框相关类名,则关闭弹框。
    • getParentsClassName方法用于获取元素及其所有父级元素的类名,返回一个类名数组。

    这种解决方案能够有效区分用户点击的区域,是处理类似需求的常用方法。

    转载地址:http://vfubz.baihongyu.com/

    你可能感兴趣的文章
    OpenCV与AI深度学习 | OpenCV中八种不同的目标追踪算法
    查看>>
    OpenCV与AI深度学习 | OpenCV图像拼接--Stitching detailed使用与参数介绍
    查看>>
    OpenCV与AI深度学习 | OpenCV如何读取仪表中的指针刻度
    查看>>
    OpenCV与AI深度学习 | OpenCV常用图像拼接方法(一) :直接拼接
    查看>>
    OpenCV与AI深度学习 | OpenCV常用图像拼接方法(二) :基于模板匹配拼接
    查看>>
    OpenCV与AI深度学习 | OpenCV快速傅里叶变换(FFT)用于图像和视频流的模糊检测(建议收藏!)
    查看>>
    OpenCV与AI深度学习 | SAM2(Segment Anything Model 2)新一代分割一切大模型介绍与使用(步骤 + 代码)
    查看>>
    OpenCV与AI深度学习 | T-Rex Label !超震撼 AI 自动标注工具,开箱即用、检测一切
    查看>>
    OpenCV与AI深度学习 | YOLO11介绍及五大任务推理演示(目标检测,图像分割,图像分类,姿态检测,带方向目标检测)
    查看>>
    OpenCV与AI深度学习 | YOLOv10在PyTorch和OpenVINO中推理对比
    查看>>
    OpenCV与AI深度学习 | YOLOv11来了:将重新定义AI的可能性
    查看>>
    OpenCV与AI深度学习 | YOLOv8自定义数据集训练实现火焰和烟雾检测(代码+数据集!)
    查看>>
    OpenCV与AI深度学习 | YOLOv8重磅升级,新增旋转目标检测,又该学习了!
    查看>>
    OpenCV与AI深度学习 | 一文带你读懂YOLOv1~YOLOv11(建议收藏!)
    查看>>
    OpenCV与AI深度学习 | 五分钟快速搭建一个实时人脸口罩检测系统(OpenCV+PaddleHub 含源码)
    查看>>
    OpenCV与AI深度学习 | 什么是 COCO 数据集?
    查看>>
    OpenCV与AI深度学习 | 低对比度缺陷检测应用实例--LCD屏幕脏污检测
    查看>>
    OpenCV与AI深度学习 | 使用 MoveNet Lightning 和 OpenCV 实现实时姿势检测
    查看>>
    OpenCV与AI深度学习 | 使用 OpenCV 创建自定义图像滤镜
    查看>>
    OpenCV与AI深度学习 | 使用 SAM 和 Grounding DINO 分割卫星图像
    查看>>