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

    你可能感兴趣的文章
    nginx添加模块与https支持
    查看>>
    Nginx的Rewrite正则表达式,匹配非某单词
    查看>>
    Nginx的使用总结(一)
    查看>>
    Nginx的是什么?干什么用的?
    查看>>
    Nginx访问控制_登陆权限的控制(http_auth_basic_module)
    查看>>
    nginx负载均衡的五种算法
    查看>>
    Nginx配置ssl实现https
    查看>>
    Nginx配置TCP代理指南
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
    查看>>
    NI笔试——大数加法
    查看>>
    NLP 基于kashgari和BERT实现中文命名实体识别(NER)
    查看>>
    NMAP网络扫描工具的安装与使用
    查看>>
    NN&DL4.3 Getting your matrix dimensions right
    查看>>
    NN&DL4.8 What does this have to do with the brain?
    查看>>
    No 'Access-Control-Allow-Origin' header is present on the requested resource.
    查看>>
    No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
    查看>>