1

我有一个 MatDialog,它在构建时由其父级提供一个 HTML 字符串。HTML 字符串是命名 div 内容的来源,并包含<table>嵌入在 html 中的标签,但由于某种原因,对话框的 scss 文件中定义的表格样式不适用于我指定为的字符串[innerHTML],尽管它适用于<table>标签直接硬编码到html文件中。

有什么方法可以让对话框呈现带有对话框组件样式模板中包含的样式的innerHTML?

    export class DialogAgreementViewer implements AfterViewInit {
      constructor(public dialogRef:
        MatDialogRef<DialogAgreementViewer>, @Inject
        (MAT_DIALOG_DATA) public data: string, protected _sanitizer : DomSanitizer){
          this.agreementText = this._sanitizer.bypassSecurityTrustHtml(data);
        }
      public agreementText : SafeHtml;
      @ViewChild('agreementText') agreementTextCtl : ElementRef;
    }

HTML:

    <p>Agreement Template</p>
    <table>.          <-- Defined table styles are applied to this table.
        <tbody>
            <tr><td>Title</td><td>Name of Work</td></tr>
        </tbody>
    </table>
    
    <div [innerHTML]='agreementText'></div> <-- Table styles not applied here.

SCSS:

    table, td {
        border: 1px solid black;
       
    }
    table {
        border-collapse: collapse;
        width: 75%
    }
4

2 回答 2

1

与组件一起导入 ViewEncapsulation:

import { Component, ViewEncapsulation } from '@angular/core';

并在装饰器中为组件设置封装,以及选择器、模板、css 样式等:

encapsulation: ViewEncapsulation.None

例如:

@Component({
  selector: 'your-app',
  templateUrl: './your.component.html',
  styleUrls: ['./your.component.css'],
  encapsulation: ViewEncapsulation.None, // <---------
})
于 2022-01-19T20:23:54.540 回答
1

您应该禁用该组件的封装。你可以这样做:

import { Component, ViewEncapsulation } from '@angular/core';
...
@Component({
  ...
  encapsulation: ViewEncapsulation.None,
})
于 2022-01-19T20:29:35.310 回答