AngularMaterial对话框/叠层有时需要在关闭后点击DOM。
创始人
2024-10-28 09:01:39
0

在使用Angular Material的对话框或叠层时,有时关闭后还需要点击一下DOM才能使背景遮罩消失。这通常是由于仍然存在某些已注销的DOM事件监听器所致。为了解决这个问题,您可以在关闭对话框或叠层时手动注销事件监听器。

以下是一个示范:

import { Component, OnInit, OnDestroy, AfterViewInit, ViewChild, ElementRef } from '@angular/core';
import { MatDialog } from '@angular/material';

@Component({
  selector: 'app-example-dialog',
  templateUrl: './example-dialog.component.html',
  styleUrls: ['./example-dialog.component.css']
})
export class ExampleDialogComponent implements OnInit, OnDestroy, AfterViewInit {
  private clickListener: any;

  constructor(private dialog: MatDialog) { }

  ngOnInit() {
  }

  ngAfterViewInit() {
    // NOTE: we need to add a short delay before adding the click listener to ensure the initialization of the dialog's backdrop element
    //       adding the click listener with no delay might fail silently and do nothing, even if the backdrop element already exists
    setTimeout(() => {
      const backdrop = document.querySelector('.cdk-overlay-backdrop');
      if (backdrop) {
        this.clickListener = () => {
          this.dialog.closeAll();
          this.removeBackdropClickListener();
        };
        backdrop.addEventListener('click', this.clickListener);
      }
    }, 200);
  }

  ngOnDestroy() {
    this.removeBackdropClickListener();
  }

  private removeBackdropClickListener() {
    const backdrop = document.querySelector('.cdk-overlay-backdrop');
    if (backdrop && this.clickListener) {
      backdrop.removeEventListener('click', this.clickListener);
      this.clickListener = null;
    }
  }
}

在这个示例中,我们在对话框初始化后添加了一个按键事件监听器。在这个监听器中,我们先注销了所有正在运行的对话框,然后移除了背景遮罩元素上的事件监听器。如此一来,关闭对话框或叠层后,它们的背景遮罩就会立刻消失,不需要再次点击DOM。

相关内容

热门资讯

现有关情况通报如下!aapok... 您好,新众亿卡看底牌这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很多玩家...
解迷透视!哈糖大菠萝有没有挂,... 解迷透视!哈糖大菠萝有没有挂,约局吧德州可以透视吗(透视)真是有辅助脚本(哔哩哔哩)1、约局吧德州可...
相较于以往!wpk俱乐部是做什... 相较于以往!wpk俱乐部是做什么的,赣牌圈总输,确实真的有辅助脚本(哔哩哔哩)1)赣牌圈总输有没有挂...
了解透视!约局吧app有挂吗,... 了解透视!约局吧app有挂吗,xpoker辅助工具(透视)好像有辅助技巧(哔哩哔哩)1、约局吧app...
刚刚!wepoker公共底牌,... 刚刚!wepoker公共底牌,乐酷有没有挂,其实是真的有辅助神器(哔哩哔哩)乐酷有没有挂是不是有人用...
揭幕透视!pokemmo辅助器... 揭幕透视!pokemmo辅助器脚本下载,菠萝德州透视脚本(透视)原来真的有辅助教程(哔哩哔哩)1、任...
有了最新消息!德普之星怎么设置... 有了最新消息!德普之星怎么设置埋牌,微玩体育辅助器,切实真的是有辅助技巧(哔哩哔哩)进入游戏-大厅左...
揭幕透视!sohoo竞技联盟辅... 揭幕透视!sohoo竞技联盟辅助器,拱趴大菠萝辅助神器(透视)一贯一直总是有辅助app(哔哩哔哩)1...
据报道!hhpoker怎么防作... 据报道!hhpoker怎么防作必弊,浙江宝宝游戏辅助器,其实是真的有辅助方法(哔哩哔哩)1、该软件可...
曝光透视!智星菠萝辅助,智星德... 曝光透视!智星菠萝辅助,智星德州插件2024最新版(透视)果然有辅助软件(哔哩哔哩)曝光透视!智星菠...