Cod*_*ger 6 html css ag-grid angular ag-grid-angular
我正在使用 Ag-Grid 表格,我想在表格的页脚中显示总行数。我如何通过使用 2 个表来实现它,1 是用于实际数据,而 2 是用于总计行。
它适用于普通的不可滚动表格,但如果它是一个固定或可滚动的表格,则顶部表格会滚动,但底部表格会粘在同一位置。
我想以相同的偏移量同时滚动两个表。
有关更多详细信息,请查看下面的屏幕截图,其中包含总底部表格。
普通表:
您可以在普通表中看到它完美地显示了总数。
在固定列表中,它没有按预期工作。
查看两个表的滚动条。
我想同时滚动两个表格。
或者除了双表之外还有其他方法可以显示总计行吗?
请指导我。
Cod*_*ger 13
最后,经过对页脚总计行的大量研发,我发现我们可以实现PinnedBootomRow以显示表格的总计。
所以我放弃了上面的想法,因为它给固定列带来了问题,而且管理 2 个表也很棘手。
感谢AreYouSiries在这里提供了一个很好的关于 plucker 的演示
也感谢Ag-Grid提供了这么好的文档和现场示例
我的 Total Row 的自定义 Plucker 版本在这里
通过遵循上述示例,我能够实现我的确切要求,现在它按预期工作。
让我添加排序步骤以实现 ag-grid 中的总行功能:
第一步 - 生成固定总行:下面的函数将生成一个空的目标对象,其中包含网格中可用的所有列。
generatePinnedBottomData(){
// generate a row-data with null values
let result = {};
this.gridColumnApi.getAllGridColumns().forEach(item => {
result[item.colId] = null;
});
return this.calculatePinnedBottomData(result);
}
Run Code Online (Sandbox Code Playgroud)
第二步计算部分或所有列的总计:您需要根据行数据计算总计并在上面生成的目标行中设置值。
calculatePinnedBottomData(target: any){
//console.log(target);
//**list of columns fo aggregation**
let columnsWithAggregation = ['age']
columnsWithAggregation.forEach(element => {
console.log('element', element);
this.gridApi.forEachNodeAfterFilter((rowNode: RowNode) => {
//if(rowNode.index < 10){
//console.log(rowNode);
//}
if (rowNode.data[element])
target[element] += Number(rowNode.data[element].toFixed(2));
});
if (target[element])
target[element] = `Age Sum: ${target[element].toFixed(2)}`;
})
//console.log(target);
return target;
}
Run Code Online (Sandbox Code Playgroud)
第三步也是最后一步:调用上面的generatePinnedBottomData()函数,您可以从 API 或本地数据库获取网格数据。在上面的例子中,我们曾经调用过onGridReady()
onGridReady(params) {
this.gridApi = params.api;
this.gridColumnApi = params.columnApi;
console.log(this.gridColumnApi.getAllGridColumns())
this.http
.get("https://raw.githubusercontent.com/ag-grid/ag-grid/master/packages/ag-grid-docs/src/olympicWinners.json")
.subscribe(data => {
this.rowData = data;
setTimeout(()=>{
let pinnedBottomData = this.generatePinnedBottomData();
this.gridApi.setPinnedBottomRowData([pinnedBottomData]);
}, 500)
});
}
Run Code Online (Sandbox Code Playgroud)
您需要将生成的数据分配给网格。
就是这样,您现在可以看到固定在网格底部的总行。
希望我的帖子能帮助您实现网格中的总行。
| 归档时间: |
|
| 查看次数: |
4487 次 |
| 最近记录: |