为什么 Angular Material table mat-paginator pagesize 不起作用?
Why does the Angular Material table mat-paginator pagesize not work?
我正在尝试在 Angular material 设计 table 上使用分页器,但 table 中的项目总是大于我在分页器中设置的页面大小。怎么了?甚至Angular Material页面上的文档也有同样的问题,参见:StackBlitz Angular Material
我已将 html 文件中分页器的页面大小设置为 5,但它总是显示超过 5 个项目。
也一直在浏览 this issue,但我不知道我在做什么了。所以希望任何人都可以提供帮助。
我的代码:
import { Component, OnInit, ViewEncapsulation, AfterViewInit, ViewChild } from '@angular/core';
import { Router } from '@angular/router';
import { MatSpinner, MatPaginator } from '@angular/material';
import { QuotationService } from './quotation.service';
import { ConfiguratedMachine } from 'app/models/ConfiguratedMachine';
import { merge } from 'rxjs';
import { tap } from 'rxjs/operators';
@Component({
selector: 'quotation',
styleUrls: ['./quotation.component.scss'],
templateUrl: './quotation.component.html',
encapsulation: ViewEncapsulation.None
})
export class QuotationComponent implements OnInit, AfterViewInit {
@ViewChild(MatPaginator, {static: true}) paginator: MatPaginator;
ngAfterViewInit() {
this.quotationService.getConfiguratedMachines().subscribe(cm => this.configuratedMachines = cm);
this.paginator.page.pipe(
tap(() => this.configuratedMachines)
).subscribe();
}
devices: any[];
configuratedMachines: ConfiguratedMachine[];
displayedColumns: string[] = ['machineid', 'customer', 'creator', 'created', 'changed', 'id'];
resultsLength = 0;
cols = [
{ field: 'Name', header: 'Machine' },
{ field: 'NameBV', header: 'Klant' },
{ field: 'User', header: 'Gemaakt door' },
{ field: 'CreatedOn', header: 'Aangemaakt op' },
{ field: 'LastChange', header: 'Laatste verandering' },
{ field: 'Id', header: 'Id' }
];
constructor(private quotationService: QuotationService, private router: Router) {
}
ngOnInit() {
this.devices = this.quotationService.getConfigMachines();
}
LoadDevice(device) {
this.quotationService.setChosenDevice(device);
this.router.navigate(['Offerte', device.Id, 'Form']);
}
}
Html
<div class="container-fluid">
<div class="example-container mat-elevation-z8">
<table mat-table [dataSource]="configuratedMachines" class="example-table" matSort matSortActive="created" matSortDisableClear matSortDirection="desc">
<ng-container matColumnDef="machineid">
<th mat-header-cell *matHeaderCellDef>Machine</th>
<td mat-cell *matCellDef="let row">{{row.MachineId}}</td>
</ng-container>
<ng-container matColumnDef="id">
<th mat-header-cell *matHeaderCellDef>Configuratie id</th>
<td mat-cell *matCellDef="let row">{{row.ConfiguratedMachineId}}</td>
</ng-container>
<ng-container matColumnDef="creator">
<th mat-header-cell *matHeaderCellDef>Gemaakt door</th>
<td mat-cell *matCellDef="let row">{{row.AddedBy}}</td>
</ng-container>
<ng-container matColumnDef="customer">
<th mat-header-cell *matHeaderCellDef>Klant</th>
<td mat-cell *matCellDef="let row">{{row.Customer.CompanyName}}</td>
</ng-container>
<ng-container matColumnDef="created">
<th mat-header-cell *matHeaderCellDef mat-sort-header disableClear>
Aangemaakt op
</th>
<td mat-cell *matCellDef="let row">{{row.CreationDate | date : 'd-M-y h:mm:ss' : '+0100' : 'nl-nl'}}</td>
</ng-container>
<ng-container matColumnDef="changed">
<th mat-header-cell *matHeaderCellDef>Laatste verandering</th>
<td mat-cell *matCellDef="let row">{{row.ChangingDate | date : 'd-M-y h:mm:ss' : '+0100' : 'nl-nl'}}</td>
</ng-container>
<tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
<tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
</table>
<mat-paginator [length]="configuratedMachines?.length" [pageSize]="10"></mat-paginator>
</div>
</div>
您必须将 this.data
声明为 MatTableDataSource<GithubIssue>
而不是 GithubIssue[]
您还必须更新代码以在 this.data 中分配值,如下所示:
this.data = new MatTableDataSource<GithubIssue>(data);
this.data.paginator = this.paginator;
this.data.sort = this.sort;
我正在尝试在 Angular material 设计 table 上使用分页器,但 table 中的项目总是大于我在分页器中设置的页面大小。怎么了?甚至Angular Material页面上的文档也有同样的问题,参见:StackBlitz Angular Material
我已将 html 文件中分页器的页面大小设置为 5,但它总是显示超过 5 个项目。
也一直在浏览 this issue,但我不知道我在做什么了。所以希望任何人都可以提供帮助。
我的代码:
import { Component, OnInit, ViewEncapsulation, AfterViewInit, ViewChild } from '@angular/core';
import { Router } from '@angular/router';
import { MatSpinner, MatPaginator } from '@angular/material';
import { QuotationService } from './quotation.service';
import { ConfiguratedMachine } from 'app/models/ConfiguratedMachine';
import { merge } from 'rxjs';
import { tap } from 'rxjs/operators';
@Component({
selector: 'quotation',
styleUrls: ['./quotation.component.scss'],
templateUrl: './quotation.component.html',
encapsulation: ViewEncapsulation.None
})
export class QuotationComponent implements OnInit, AfterViewInit {
@ViewChild(MatPaginator, {static: true}) paginator: MatPaginator;
ngAfterViewInit() {
this.quotationService.getConfiguratedMachines().subscribe(cm => this.configuratedMachines = cm);
this.paginator.page.pipe(
tap(() => this.configuratedMachines)
).subscribe();
}
devices: any[];
configuratedMachines: ConfiguratedMachine[];
displayedColumns: string[] = ['machineid', 'customer', 'creator', 'created', 'changed', 'id'];
resultsLength = 0;
cols = [
{ field: 'Name', header: 'Machine' },
{ field: 'NameBV', header: 'Klant' },
{ field: 'User', header: 'Gemaakt door' },
{ field: 'CreatedOn', header: 'Aangemaakt op' },
{ field: 'LastChange', header: 'Laatste verandering' },
{ field: 'Id', header: 'Id' }
];
constructor(private quotationService: QuotationService, private router: Router) {
}
ngOnInit() {
this.devices = this.quotationService.getConfigMachines();
}
LoadDevice(device) {
this.quotationService.setChosenDevice(device);
this.router.navigate(['Offerte', device.Id, 'Form']);
}
}
Html
<div class="container-fluid">
<div class="example-container mat-elevation-z8">
<table mat-table [dataSource]="configuratedMachines" class="example-table" matSort matSortActive="created" matSortDisableClear matSortDirection="desc">
<ng-container matColumnDef="machineid">
<th mat-header-cell *matHeaderCellDef>Machine</th>
<td mat-cell *matCellDef="let row">{{row.MachineId}}</td>
</ng-container>
<ng-container matColumnDef="id">
<th mat-header-cell *matHeaderCellDef>Configuratie id</th>
<td mat-cell *matCellDef="let row">{{row.ConfiguratedMachineId}}</td>
</ng-container>
<ng-container matColumnDef="creator">
<th mat-header-cell *matHeaderCellDef>Gemaakt door</th>
<td mat-cell *matCellDef="let row">{{row.AddedBy}}</td>
</ng-container>
<ng-container matColumnDef="customer">
<th mat-header-cell *matHeaderCellDef>Klant</th>
<td mat-cell *matCellDef="let row">{{row.Customer.CompanyName}}</td>
</ng-container>
<ng-container matColumnDef="created">
<th mat-header-cell *matHeaderCellDef mat-sort-header disableClear>
Aangemaakt op
</th>
<td mat-cell *matCellDef="let row">{{row.CreationDate | date : 'd-M-y h:mm:ss' : '+0100' : 'nl-nl'}}</td>
</ng-container>
<ng-container matColumnDef="changed">
<th mat-header-cell *matHeaderCellDef>Laatste verandering</th>
<td mat-cell *matCellDef="let row">{{row.ChangingDate | date : 'd-M-y h:mm:ss' : '+0100' : 'nl-nl'}}</td>
</ng-container>
<tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
<tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
</table>
<mat-paginator [length]="configuratedMachines?.length" [pageSize]="10"></mat-paginator>
</div>
</div>
您必须将 this.data
声明为 MatTableDataSource<GithubIssue>
而不是 GithubIssue[]
您还必须更新代码以在 this.data 中分配值,如下所示:
this.data = new MatTableDataSource<GithubIssue>(data);
this.data.paginator = this.paginator;
this.data.sort = this.sort;