分页在 mat-paginator (Angular 7) 中的第一次加载时不起作用
Pagination does not work on first load in mat-paginator (Angular 7)
我正在使用 mat-paginator 为我的 table 分页。但是,分页在第一次加载页面时不起作用。但是,如果我在 table 上执行像一行 delete/edit 这样的操作,那么分页就会开始工作。我认为这是因为没有在第一次加载时向分页器提供值。但我不确定如何解决这个问题。
export class ProjectDashboardComponent implements OnInit {
@ViewChild(MatPaginator) paginator: MatPaginator;
public projects = [];
public noProject = true;
displayedColumns: string[] = ['projectName', 'description', 'action'];
dataSource: MatTableDataSource<IProjectData>;
constructor(public dialog: MatDialog,
private _projectService: ProjectService,
private request: RequestService,
private router: Router,
public snackBar: MatSnackBar,
private dialogService: ConfirmationDialogService) { }
ngOnInit() {
this.listProject();
}
listProject() {
const responseSubr = this.request.get<Array<IProject>>('projects');
responseSubr.subscribe(result => {
this.projects = result;
this.dataSource = new MatTableDataSource<IProjectData>(result);
this.dataSource.paginator = this.paginator;
if (this.projects.length === 0) {
this.noProject = true;
} else {
this.noProject = false;
}
});
}
openDialog(): void {
const dialogRef = this.dialog.open(AddProjectDialogComponent, {
width: '500px'
});
dialogRef.afterClosed().subscribe(result => {
this.listProject();
});
}
openEditDialog(project): void {
const projectData = project;
const dialogRef = this.dialog.open(EditProjectComponent, {
width: '500px',
data : projectData
});
dialogRef.afterClosed().subscribe(result => {
this.listProject();
});
}
public deleteProject(project: IProject) {
const msg = 'Are you sure to delete this project ?';
this.dialogService.openConfirmDialog(msg)
.afterClosed().subscribe(res => {
if (res) {
this._projectService.deleteProject(project.projectId)
.subscribe(projects => {
this.listProject();
});
}
});
}
public onViewClick(project: IProject) {
this.router.navigate(['/components', project.projectId]);
}
}
我尝试在调用 listProject()
之前将 this.dataSource.paginator = this.paginator;
行放在 ngOnInit() 中,但这没有帮助。
listProject() {
setTimeout(() =>
const responseSubr = this.request.get<Array<IProject>>('projects');
responseSubr.subscribe(result => {
this.projects = result;
this.dataSource = new MatTableDataSource<IProjectData>(result);
this.dataSource.paginator = this.paginator;
if (this.projects.length === 0) {
this.noProject = true;
} else {
this.noProject = false;
}
});
);
}
我正在使用 mat-paginator 为我的 table 分页。但是,分页在第一次加载页面时不起作用。但是,如果我在 table 上执行像一行 delete/edit 这样的操作,那么分页就会开始工作。我认为这是因为没有在第一次加载时向分页器提供值。但我不确定如何解决这个问题。
export class ProjectDashboardComponent implements OnInit {
@ViewChild(MatPaginator) paginator: MatPaginator;
public projects = [];
public noProject = true;
displayedColumns: string[] = ['projectName', 'description', 'action'];
dataSource: MatTableDataSource<IProjectData>;
constructor(public dialog: MatDialog,
private _projectService: ProjectService,
private request: RequestService,
private router: Router,
public snackBar: MatSnackBar,
private dialogService: ConfirmationDialogService) { }
ngOnInit() {
this.listProject();
}
listProject() {
const responseSubr = this.request.get<Array<IProject>>('projects');
responseSubr.subscribe(result => {
this.projects = result;
this.dataSource = new MatTableDataSource<IProjectData>(result);
this.dataSource.paginator = this.paginator;
if (this.projects.length === 0) {
this.noProject = true;
} else {
this.noProject = false;
}
});
}
openDialog(): void {
const dialogRef = this.dialog.open(AddProjectDialogComponent, {
width: '500px'
});
dialogRef.afterClosed().subscribe(result => {
this.listProject();
});
}
openEditDialog(project): void {
const projectData = project;
const dialogRef = this.dialog.open(EditProjectComponent, {
width: '500px',
data : projectData
});
dialogRef.afterClosed().subscribe(result => {
this.listProject();
});
}
public deleteProject(project: IProject) {
const msg = 'Are you sure to delete this project ?';
this.dialogService.openConfirmDialog(msg)
.afterClosed().subscribe(res => {
if (res) {
this._projectService.deleteProject(project.projectId)
.subscribe(projects => {
this.listProject();
});
}
});
}
public onViewClick(project: IProject) {
this.router.navigate(['/components', project.projectId]);
}
}
我尝试在调用 listProject()
之前将 this.dataSource.paginator = this.paginator;
行放在 ngOnInit() 中,但这没有帮助。
listProject() {
setTimeout(() =>
const responseSubr = this.request.get<Array<IProject>>('projects');
responseSubr.subscribe(result => {
this.projects = result;
this.dataSource = new MatTableDataSource<IProjectData>(result);
this.dataSource.paginator = this.paginator;
if (this.projects.length === 0) {
this.noProject = true;
} else {
this.noProject = false;
}
});
);
}