角材质 *matNoDataRow 不起作用

jul*_*lki 11 angular-material angular

我制作了一个 MatTable,您可以在其中进行过滤。如果没有与过滤器匹配的数据,我想使用Angular Material 文档中提到的 * matNoDataRow指令显示文本。但是,它不像 Angular Material 的示例那样工作。有什么我忘记了吗?还是该指令尚未生效?我使用 Angular 9。

这是我的表:

<mat-form-field color="accent" appearance="fill" >
    <mat-label >Filter</mat-label>
    <input matInput (keyup)="doFilter($event.target.value)" placeholder="filter this table" (click)="searching=true" #input >
    <button mat-icon-button matSuffix (click)="input.value=''; doFilter(''); searching= !searching" color="accent">
        <mat-icon *ngIf="!searching">search</mat-icon>
        <mat-icon *ngIf="searching">clear</mat-icon>
    </button>
</mat-form-field>

<div class="sticky-container" style="margin-top: 2em;">
    <table mat-table [dataSource]="dataSource" class="mat-elevation-z8" matSort matSortActive="EXPIRY DATE" matSortDirection="asc" matSortDisableClear>

        <ng-container matColumnDef="id">
            <th mat-header-cell *matHeaderCellDef mat-sort-header>CUSTOMER ID</th>
            <td mat-cell *matCellDef="let customer; let i = index" class="no-outline" 
                routerLink="/summary/customer/{{customerService.id}}">{{customer.id}}</td>
        </ng-container>

        <ng-container matColumnDef="exDate">
            <th mat-header-cell *matHeaderCellDef mat-sort-header>EXPIRY DATE</th>
            <td mat-cell *matCellDef="let customer; let i = index" class="table-bold no-outline" 
                routerLink="/summary/customer/{{customerService.id}}">{{customer.exDate | date: "dd.MM.yyyy"}}</td>
        </ng-container>

        <ng-container matColumnDef="companyName">
            <th mat-header-cell *matHeaderCellDef mat-sort-header>COMPANY / PARTNER</th>
            <td mat-cell *matCellDef="let customer; let i = index"  class="no-outline" 
                routerLink="/summary/customer/{{customerService.id}}">{{customer.companyName}}</td>
        </ng-container>

        <ng-container matColumnDef="export">
            <th mat-header-cell *matHeaderCellDef></th>
            <td mat-cell *matCellDef="let customer; let i = index">
                <button mat-icon-button matTooltip="export" (click)="export()">
                    <mat-icon color="primary">get_app</mat-icon>
                </button>
            </td>
        </ng-container>
        
        <tr mat-header-row *matHeaderRowDef="displayedColumns; sticky: true" ></tr>
        <tr mat-row *matRowDef="let row; columns: displayedColumns; let i = index" (mouseover)="customerService.getId([row.id])"></tr>
        
        <!-- Row shown when there is no matching data.-->
        <tr class="mat-row" *matNoDataRow>
            <td class="mat-cell" colspan="4">No data matching the filter "{{input.value}}"</td>
        </tr>

    </table>
    
    <mat-paginator [pageSize]="10" [pageSizeOptions]="[10, 20, 30, 100, dataSource.data.length]" color="accent"></mat-paginator>
</div>
Run Code Online (Sandbox Code Playgroud)

更新:这是我实施它的方式。它不起作用的唯一原因是我必须将我的 Angular 更新到版本 10。

Jes*_*sse 13

该功能仅在最新版本的 Angular (v10) 中可用。如果您将文档切换为显示 v9(现在显示 9.2.4),您将看到该功能不是 API 的一部分。

也就是说,我也无法让它工作。即使在 Angular 10 中。:(

更新:我确实让它工作了。(我使用的是 Angular 10.0.1)。我的工作代码看起来正是你如何实现它的。所以升级到 Angular 10 应该对你有用。

  • 我发现的此功能的最佳文档来源(带有 mat-table 的示例)是 github 存储库中的单元测试:https://github.com/angular/components/blob/master/src/material/表/表.spec.ts (3认同)
  • 对于任何试图使其工作的人来说,还有两点需要考虑: 1. 将 `CdkColumnDef` 添加到模块的提供者中,该模块的组件正在使用此功能。否则,即使导入了“MatTableModule”,您也会看到“NullInjectorError:没有 CdkColumnDef 的提供程序!”。2. 使用`&lt;tr class="mat-row" *matNoDataRow&gt;`而不是`&lt;tr mat-row *matNoDataRow&gt;`。否则,您将不会看到带有消息的“&lt;td&gt;”,也不会看到错误。 (2认同)
  • 还有一件重要的事情。您应该使用 `&lt;td class="mat-cell"&gt;` 而不是 `&lt;td mat-cell&gt;`。 (2认同)