Angular为什么要将`cdk-overlay-container`添加到body中?
创始人
2024-10-29 23:00:53
0

在 Angular 中,cdk-overlay-container 是 Overlay 模块使用的一个容器,用于显示过渡效果和实现弹出框等组件。将 cdk-overlay-container 添加到 body 是为了确保 Overlay 可以覆盖整个页面,并且不会受到其他元素的影响。

以下是一些代码示例,说明如何手动将 cdk-overlay-container 添加到 body:

app.component.html:


  

app.component.ts:

import { Component, Injector, ViewContainerRef } from '@angular/core';
import { Overlay, OverlayConfig, OverlayContainer } from '@angular/cdk/overlay';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {

  constructor(private overlay: Overlay, private injector: Injector, private overlayContainer: OverlayContainer) { }

  showOverlay() {
    const overlayRef = this.overlay.create(this.getOverlayConfig());
    const overlayPortal = new TemplatePortal(this.overlayTemplate, this.viewContainerRef);
    overlayRef.attach(overlayPortal);
  }

  private getOverlayConfig(): OverlayConfig {
    const positionStrategy = this.overlay.position().global().centerHorizontally().centerVertically();
    const overlayConfig = new OverlayConfig({
      positionStrategy,
      hasBackdrop: true,
      scrollStrategy: this.overlay.scrollStrategies.block(),
      panelClass: 'my-overlay-container'
    });
    return overlayConfig;
  }

  get overlayTemplate(): TemplateRef {
    return this.injector.get(TemplateRef);
  }

  get viewContainerRef(): ViewContainerRef {
    return this.injector.get(ViewContainerRef);
  }

}

在上面的代码中,我们通过 Overlay 模块创建了一个 Overlay,并使用 TemplatePortal 将模板渲染到 Overlay 上。需要注意的是,在 getOverlayConfig 方法中,我们指定了一个 CSS 类名 my-overlay-container,这个类

相关内容

热门资讯

透视大纲!有哪些免费的wpk作... 透视大纲!有哪些免费的wpk作必弊码(HHpoker必备)确实是有辅助神器(哔哩哔哩)1、用户打开应...
透视窍要!epoker透视底牌... 透视窍要!epoker透视底牌(HHpoker安装包)其实真的是有辅助插件(哔哩哔哩)1、epoke...
透视妙计!wepoker透视脚... 透视妙计!wepoker透视脚本是什么(HHpoker德州)本来真的是有辅助app(哔哩哔哩)1、点...
透视妙计!we poker辅助... 透视妙计!we poker辅助器下载(WePoKer数据)果然真的有辅助脚本(哔哩哔哩)1、打开软件...
透视窍门!wpk俱乐部辅助器(... 透视窍门!wpk俱乐部辅助器(HHpoker教程)真是是真的有辅助app(哔哩哔哩)小薇(辅助器软件...
透视手段!佛手大菠萝辅助(AA... 透视手段!佛手大菠萝辅助(AApoker靠谱)都是真的有辅助脚本(哔哩哔哩)小薇(辅助器软件下载)致...
透视教程书!wpk软件是正规的... 透视教程书!wpk软件是正规的吗(HHpoker下载)确实是有辅助技巧(哔哩哔哩)1、起透看视 wp...
透视阶段!wepoker买脚本... 透视阶段!wepoker买脚本靠谱吗(WePoKer新版本)确实存在有辅助插件(哔哩哔哩)1、wep...
透视指南!wepoker透视方... 透视指南!wepoker透视方法(HHpoker机器人)一直真的是有辅助攻略(哔哩哔哩)1、玩家可以...
透视策略!sohoo poke... 透视策略!sohoo poker辅助(WePoKer透视脚本)一贯存在有辅助app(哔哩哔哩)1、很...