没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:龚雪|2022-12-13 11:07:01.500|阅读 1 次
概述:本文将为大家介绍如何使用界面组件Kendo UI for Angular的 Angular Material来实现数据格的各种功能,欢迎下载最新版组件体验!
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
Kendo UI致力于新的开发,来满足不断变化的需求,通过React框架的Kendo UI JavaScript封装来支持React Javascript框架。Kendo UI for Angular是专用于Angular开发的专业级Angular组件,telerik致力于提供纯粹的高性能Angular UI组件,无需任何jQuery依赖关系。
Telerik_KendoUI产品技术交流群:726377843 欢迎一起进群讨论
Angular Material是Angular团队创建的一个流行库,本文将为大家介绍如何使用mat-table来构建一个数据网格。
在上文中,我们为大家介绍了如何开始使用Angular Material构建一个数据网格(点击这里回顾>>),本文将继续介绍如何进行排序、过滤和分页等。
当显示大量数据时,分页是一个很好的功能,为了提供分页,Angular Material提供了mat-paginator。
首先,我们将模块MatPaginatorModule导入到模块中。
import { MatPaginatorModule } from '@angular/material/paginator'; @NgModule({ declarations: [AppComponent], imports: [ BrowserModule, BrowserAnimationsModule, MatTableModule, MatPaginatorModule, ],
编辑app.component.ts并为分页器ViewChild添加一个新属性,要从模板访问MatPagination,请将代码更新到订阅中,并将MatTableDataSource的一个新示例设置为datasource,该实例使用来自订阅和分页器视图子的数据。
@ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator; ngOnInit(): void { this.nbaService.getData().subscribe((data) => { this.dataSource = new MatTableDataSource<any>(data); this.dataSource.paginator = this.paginator; }); }
接下来,更新模板来将表与数据源连接起来,并使用分页选项列表配置表分页器,添加指令showFirstLastButton激活导航按钮从最后移动到第一个。
<table mat-table [dataSource]="dataSource" class="mat-elevation-z8" #mytable> ... </table> <mat-paginator [pageSizeOptions]="[3, 5, 10]" showFirstLastButtons></mat-paginator>
要允许用户对数据进行排序,请使用MatSort。首先,在app.module中导入MatSortModule。
import { MatSortModule } from '@angular/material/sort'; @NgModule({ declarations: [AppComponent], imports: [ BrowserModule, BrowserAnimationsModule, MatSortModule, MatTableModule, MatPaginatorModule, ], providers: [], bootstrap: [AppComponent], }) export class AppModule {}
首先,为分页器添加一个viewchild,将MatSort导入app.component.ts,并声明一个viewchild排序来将其链接到模板。
import { MatSort } from '@angular/material/sort'; @ViewChild(MatSort, { static: true }) sort!: MatSort;
在ngOnInit生命周期中,赋值给数据源排序属性MathSort viewchild。
ngOnInit(): void { this.nbaService.getData().subscribe((data) => { this.dataSource = new MatTableDataSource<any>(data); this.dataSource.paginator = this.paginator; this.dataSource.sort = this.sort; }); }
编辑app.component.html,将matSort指令添加到表中,并为每一列添加mat-sort标题。
<table mat-table [dataSource]="dataSource" class="mat-elevation-z8" #mytable matSort> <tr mat-header-row *matHeaderRowDef="columns" ></tr> <tr mat-row *matRowDef="let row; columns: columns;"></tr> <ng-container matColumnDef="name"> <th mat-header-cell *matHeaderCellDef mat-sort-header>Name</th> <td mat-cell *matCellDef="let t">{{ t.first_name }}</td> </ng-container> <ng-container matColumnDef="team"> <th mat-header-cell *matHeaderCellDef mat-sort-header>Position</th> <td mat-cell *matCellDef="let t">{{ t.position }}</td> </ng-container> </table>
Angular Material现在并没有附带特定的组件或过滤器指令,为了解决这个问题,必须手动实现数据过滤。
我们定义了一个名为filter的方法,每当用户在mat-input控件中输入或删除一个字符时,都会执行该方法:
filter(event: Event) { const filter = (event.target as HTMLInputElement).value; this.dataSource.filter = filter.trim().toLowerCase(); }
当初始化dataSource的filter属性时,视图中显示的数据将被更新。
<input matInput (keyup)="filter($event)" placeholder="find">
结果:
有时我们必须在表或列表中显示大量的数据,在DOM中添加所有这些元素会导致问题,并迫使应用程序变慢。
Angular CDK提供了一个虚拟滚动来只显示视图中项目的一小部分,它保持了DOM元素的数量不变,提高了应用程序的性能。
不幸的是,默认情况下,虚拟滚动CDK不能与mat-table一起工作,但是包(不是官方的)是一个允许在mat-table中使用虚拟滚动的指令。
import { MatSortModule } from '@angular/material/sort'; import { ScrollingModule } from '@angular/cdk/scrolling'; import { TableVirtualScrollModule } from 'ng-table-virtual-scroll'; @NgModule({ declarations: [AppComponent], imports: [ BrowserModule, BrowserAnimationsModule, MatSortModule, MatTableModule, MatPaginatorModule, ScrollingModule, TableVirtualScrollModule, ], providers: [], bootstrap: [AppComponent], }) export class AppModule {},
将MatTableDataSource更改为TableVirtualScrollDataSource。
this.nbaService.getData().subscribe((data) => { this.dataSource = new TableVirtualScrollDataSource(data); });
注意:ng-table-virtual-scroll不是官方包。
编辑模板:
<cdk-virtual-scroll-viewport tvsItemSize="30" headerHeight="56" class="wrapper mat-elevation-z2" style="height: 400px" > .... </cdk-virtual-scroll-viewport>
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@wqylolg.cn
文章转载自:慧都网从版本2025.2.2开始, Stimulsoft 产品中引入了一个新的关系参数JoinType 。它定义了两个数据源之间的连接类型。在本文中,我们将深入探讨如何使用此参数。
本文将详细介绍如何使用 C# 和 Spire.XLS for .NET 库将 Excel XLS 或 XLSX 文件转换为 Markdown 格式。
Webix 是一套完整的前端开发框架,它允许开发者利用 JavaScript、CSS 和 HTML5 技术,快速构建出富交互性的 Web 应用程序。该框架提供了超过 100 个预制且可高度定制的组件,涵盖了数据表格、图表、表单、布局等各类常见的用户界面元素。无论是经验丰富的专业开发者,还是初涉 Web 开发领域的新手,都能从 Webix 的易用性和强大功能中受益。
CAD VCL Multiplatform是一个高质量的多功能源代码库,可用于 Delphi 和 C++Builder 应用程序。支持 2D 和 3D CAD 格式,包括DWG、DXF、 HPGL PLT、HGL、STEP、IGES、STL、ACIS SAT、BREP、CGM、SVG等。该产品不需要安装 AutoCAD® 或其他附加应用程序。
全新升级的Kendo UI,是创建数据丰富的Web应用程序的最完整UI库。
Kendo UI for Angular完整的Angular UI组件库,助力构建高性能的现代Angular应用。
Kendo UI for jQuery完整的jQuery UI组件库,可快速构建出色的高性能响应式Web应用程序。
Kendo UI for Vue创建响应式Web应用的完整UI组件库。
Kendo UI Support for React支持React Javascript框架,更快地构建更好的应用程序。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@wqylolg.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢