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

    你可能感兴趣的文章
    noi 1996 登山
    查看>>
    noi 7827 质数的和与积
    查看>>
    NOI-1.3-11-计算浮点数相除的余数
    查看>>
    NOI2010 海拔(平面图最大流)
    查看>>
    NOIp2005 过河
    查看>>
    NOIP2011T1 数字反转
    查看>>
    NOIP2014 提高组 Day2——寻找道路
    查看>>
    noip借教室 题解
    查看>>
    NOIP模拟测试19
    查看>>
    NOIp模拟赛二十九
    查看>>
    Vue3+element plus+sortablejs实现table列表拖拽
    查看>>
    Nokia5233手机和我装的几个symbian V5手机软件
    查看>>
    non linear processor
    查看>>
    Non-final field ‘code‘ in enum StateEnum‘
    查看>>
    none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
    查看>>
    None还可以是函数定义可选参数的一个默认值,设置成默认值时实参在调用该函数时可以不输入与None绑定的元素...
    查看>>
    NoNodeAvailableException None of the configured nodes are available异常
    查看>>
    Vue.js 学习总结(16)—— 为什么 :deep、/deep/、>>> 样式能穿透到子组件
    查看>>
    nopcommerce商城系统--文档整理
    查看>>
    NOPI读取Excel
    查看>>