我有一个解决方案,但并不完美。
<table mat-table [dataSource]="dataSource"
multiTemplateDataRows class="mat-elevation-z8">
<ng-container matColumnDef="{{column}}"
*ngFor="let column of columnsToDisplay">
<th mat-header-cell *matHeaderCellDef>
{{column !== 'action' ? column : ''}}
</th>
<ng-container *ngIf="column !== 'action'">
<td mat-cell *matCellDef="let aliasesData">
<span>{{aliasesData[column]}}</span>
</td>
</ng-container>
<ng-container *ngIf="column === 'action'">
<td mat-cell *matCellDef="let aliasesData">
<span>
<button>Edit</button>
<button>Delete</button>
</span>
</td>
</ng-container>
</ng-container>
<tr mat-header-row *matHeaderRowDef="columnsToDisplay"></tr>
<tr mat-row *matRowDef="let row; columns: columnsToDisplay;"></tr>
</table>
您可以使用ngIf绑定来检查列操作并仅显示按钮。
或有 2 列显示阵列
columnsToDisplay = ['id', 'domain_id', 'source'];
columnsForConfig = ['id', 'domain_id', 'source', 'action'];
并将一个用于渲染,另一个用于底部的配置,并在ngFor绑定之后将操作作为单独的部分。
<table mat-table [dataSource]="dataSource" multiTemplateDataRows class="mat-elevation-z8">
<ng-container matColumnDef="{{column}}" *ngFor="let column of columnsToDisplay">
<th mat-header-cell *matHeaderCellDef>
{{column}}
</th>
<td mat-cell *matCellDef="let aliasesData">
<span>{{aliasesData[column]}}</span>
</td>
</ng-container>
<ng-container matColumnDef="action">
<th mat-header-cell *matHeaderCellDef>
actions
</th>
<td mat-cell *matCellDef="let aliasesData">
<button>Edit</button>
<button>Delete</button>
</td>
</ng-container>
<tr mat-header-row *matHeaderRowDef="columnsForConfig"></tr>
<tr mat-row *matRowDef="let row; columns: columnsForConfig;"></tr>
</table>