Angular - 使用组件包装器和组件作为参数的材料模态框
创始人
2024-10-14 23:00:35
0

要实现“Angular - 使用组件包装器和组件作为参数的材料模态框”,你可以按照以下步骤进行操作:

  1. 首先,创建一个名为modal-wrapper的组件包装器组件。这个组件将负责显示和管理材料模态框的打开和关闭。
import { Component, ComponentFactoryResolver, OnInit, ViewChild, ViewContainerRef } from '@angular/core';
import { MatDialog } from '@angular/material/dialog';

@Component({
  selector: 'app-modal-wrapper',
  template: `
    
`, }) export class ModalWrapperComponent implements OnInit { @ViewChild('modalContainerRef', { read: ViewContainerRef }) modalContainerRef: ViewContainerRef; constructor(private dialog: MatDialog, private componentFactoryResolver: ComponentFactoryResolver) {} ngOnInit(): void {} openModal(component: any): void { this.modalContainerRef.clear(); const componentFactory = this.componentFactoryResolver.resolveComponentFactory(component); const componentRef = this.modalContainerRef.createComponent(componentFactory); const dialogRef = this.dialog.open(componentRef.instance); dialogRef.afterClosed().subscribe(() => { componentRef.destroy(); }); } }
  1. 创建一个材料模态框组件,例如my-dialog组件,它将作为参数传递给modal-wrapper组件。
import { Component } from '@angular/core';
import { MatDialogRef } from '@angular/material/dialog';

@Component({
  selector: 'app-my-dialog',
  template: `
    

My Dialog

Hello, this is my custom dialog content.

`, }) export class MyDialogComponent { constructor(public dialogRef: MatDialogRef) {} }
  1. 在需要打开材料模态框的组件中使用modal-wrapper组件。


import { Component } from '@angular/core';
import { ModalWrapperComponent } from './modal-wrapper.component';
import { MyDialogComponent } from './my-dialog.component';

@Component({
  selector: 'app-my-component',
  template: `
    
    
  `,
})
export class MyComponent {
  constructor(private modalWrapper: ModalWrapperComponent) {}

  openDialog(): void {
    this.modalWrapper.openModal(MyDialogComponent);
  }
}

以上代码示例演示了如何创建一个可复用的组件包装器modal-wrapper,以及如何使用modal-wrapper组件来打开一个具体的材料模态框my-dialog

相关内容

热门资讯

6分钟辅助!hhpoker是真... 6分钟辅助!hhpoker是真的假的,hhpoker真的有透视吗,演示教程(真是有挂)1、每一步都需...
第七分钟辅助!we poker... 第七分钟辅助!we poker插件,we poker免费辅助器,手筋教程(有挂方式)暗藏猫腻,小编详...
七分钟辅助!aa poker辅... 七分钟辅助!aa poker辅助包,pokemmo脚本辅助器下载,讲义教程(有挂秘籍)1、pokem...
第四分钟辅助!wepoker辅... 第四分钟辅助!wepoker辅助器安装包定制,aapoker透视脚本,大纲教程(有挂总结)所有人都在...
第四分钟辅助!wpk透视辅助靠... 第四分钟辅助!wpk透视辅助靠谱吗,wepoker透视苹果系统,诀窍教程(有挂猫腻);运wepoke...
七分钟辅助!aapoker透视... 七分钟辅助!aapoker透视脚本入口,wejoker开挂,学习教程(有挂教程)1、打开软件启动之后...
第四分钟辅助!淘宝买wepok... 第四分钟辅助!淘宝买wepoker透视有用吗,wpk俱乐部怎么作弊,积累教程(有挂规律)1、下载好淘...
6分钟辅助!we-poker软... 6分钟辅助!we-poker软件,购买的wpk辅助在哪里下载,积累教程(有挂技巧)购买的wpk辅助在...
第2分钟辅助!如何下载wepo... 第2分钟辅助!如何下载wepoker安装包,newpoker怎么安装脚本,教程书教程(今日头条)1、...
4分钟辅助!wepoker钻石... 4分钟辅助!wepoker钻石怎么看底牌,wepoker辅助器有哪些功能,法门教程(有挂详细)该软件...