gpt4 book ai didi

Angular Material 表不显示数据

转载 作者:太空狗 更新时间:2023-10-29 17:31:59 25 4
gpt4 key购买 nike

需要在客户端进行分页排序的请引用this link

这是我尝试过的。数据正在控制台中加载。但它不显示在网格或垫子表上。

我在控制台中没有任何错误。我能够在控制台中看到数据,但数据未加载到网格中。

谁能告诉我我做错了什么?

发出数据的实际数据库。

export class FormsDatabase {

formsList = new BehaviorSubject([]);
get data(){

return this.formsList.value;
}

constructor(private _formsServicedata: FormsService){
this._formsServicedata.getAllFormData('').subscribe((form)=>{
console.log("Form DataSource: ");
this.formsList.next(form);
})
}

}


export class FormDataSource extends DataSource<any>{

constructor( private formsDb: FormsDatabase,public
paginator:MatPaginator , public sort: MatSort
) {
super()
}

connect():Observable<any>{
const formsData=[
this.formsDb.formsList ,
this.sort.sortChange
];

return Observable.merge(...formsData).map(()=>{
this.getSortedData();
})


}

排序函数对数据进行排序

      getSortedData(){

const data = this.formsDb.data.slice();
if(!this.sort.active || this.sort.direction==''){ return data;}

return data.sort((a,b)=>{

let propertyA:number|string='';
let propertyB:number|string='';

switch(this.sort.active)
{
case 'formname': [propertyA,propertyB]=
[a.formname,b.formname];break;
case 'displaytext': [propertyA,propertyB]=
[a.displaytext,b.displaytext];break;
case 'sortorder': [propertyA,propertyB]=
[a.sortorder,b.sortorder];break;
}

let valueA = isNaN(+propertyA) ? propertyA : +propertyA;
let valueB = isNaN(+propertyB) ? propertyB : +propertyB;

return (valueA < valueB?-1:1)*(this.sort.direction=='asc'?1:-1);
});
}

disconnect() { }

}

HTML

  <mat-table #table [dataSource]="dataSource" matSort>

<ng-container matColumnDef="formname">
<mat-header-cell *matHeaderCellDef mat-sort-header> FORM NAME
</mat-header-cell>
<mat-cell *matCellDef="let element"> {{element.formname}}
</mat-cell>
</ng-container>


<ng-container matColumnDef="displaytext">
<mat-header-cell *matHeaderCellDef mat-sort-header> DISPLAY TEXT </mat-header-cell>
<mat-cell *matCellDef="let element"> {{element.displaytext}} </mat-cell>
</ng-container>

<ng-container matColumnDef="sortorder">
<mat-header-cell *matHeaderCellDef mat-sort-header> SORT ORDER</mat-header-cell>
<mat-cell *matCellDef="let element"> {{element.sortorder}} </mat-cell>
</ng-container>

<mat-header-row *matHeaderRowDef="displayedColumns"></mat-header-row>
<mat-row *matRowDef="let row; columns: displayedColumns;"></mat-row>
</mat-table>

<mat-paginator #paginator
[pageSize]="10"
[pageSizeOptions]="[5, 10, 20]"
[showFirstLastButtons]="true">
</mat-paginator>
</div>

服务:

Forms Service 具有以下方法,它返回可观察的表单列表

  getAllFormData(orderBy:string) {
return this.af.list('/forms');
}

最佳答案

添加 ngIf="dataSource"<mat-table>标签。

如果数据是异步的,就会出现这个问题。在获取数据之前加载 DOM。

检查 dataSource在渲染 DOM 之前。

关于 Angular Material 表不显示数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48855289/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com