博客
关于我
关于点击弹框外部区域弹框关闭的交互处理
阅读量: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/

    你可能感兴趣的文章
    opencv3-Mat对象
    查看>>
    opencv30-图像矩
    查看>>
    opencv32-基于距离变换和分水岭的图像分割
    查看>>
    opencv4-图像操作
    查看>>
    opencv5-图像混合
    查看>>
    opencv6-调整图像亮度和对比度
    查看>>
    opencv7-绘制形状和文字
    查看>>
    opencv8-图像模糊
    查看>>
    opencv9-膨胀和腐蚀
    查看>>
    OpenCV_ cv2.imshow()
    查看>>
    opencv_core.dir/objects.a(vs_version.rc.obj)‘ is incompatible with i386:x86-64 output
    查看>>
    opencv——图像缩放1(resize)
    查看>>
    opencv——最简单的视频读取
    查看>>
    Opencv——模块介绍
    查看>>
    OpenCV与AI深度学习 | 2024年AI初学者需要掌握的热门技能有哪些?
    查看>>
    OpenCV与AI深度学习 | CIB-SE-YOLOv8: 优化的YOLOv8, 用于施工现场的安全设备实时检测 !
    查看>>
    OpenCV与AI深度学习 | CoTracker3:用于卓越点跟踪的最新 AI 模型
    查看>>
    OpenCV与AI深度学习 | OpenCV中八种不同的目标追踪算法
    查看>>
    OpenCV与AI深度学习 | OpenCV图像拼接--Stitching detailed使用与参数介绍
    查看>>
    OpenCV与AI深度学习 | OpenCV如何读取仪表中的指针刻度
    查看>>