当前位置: 首页 > news >正文

那些网站分享pr做的视频外贸网站建设制作教程

那些网站分享pr做的视频,外贸网站建设制作教程,网站开发开源代码,企业邮箱有哪几种在angular中,MatTable构建简单,使用范围广。但某些时候会出现卡顿 卡顿情景: 1:一次性请求太多的数据 2:一次性渲染太多数据,这会花费CPU很多时间 3:行内嵌套复杂的元素 4:使用过多的…

在angular中,MatTable构建简单,使用范围广。但某些时候会出现卡顿

卡顿情景:

1一次性请求太多的数据

2一次性渲染太多数据,这会花费CPU很多时间

3行内嵌套复杂的元素

4使用过多的ngStyle或者ngClass。或者一些额外的class

        import { MatTableDataSource } from '@angular/material/table';    
...const data: IDemoRow[] = [];for (let i = 0; i < 8000; i++) {data.push({studentId: `studentId-${i + 1}`,name: `name-${i}`,className: `className-${i}`,age: i,address: `address-${i}`,studySubjects: ['studySubjects-1','studySubjects-2','studySubjects-3','studySubjects-4','studySubjects-5','studySubjects-6',],grade: 4});}this.dataSource = new MatTableDataSource(data);

第一次渲染会卡顿,拖动滚动条时会出现空白现象。

提升办法:

1分页

使用MatPaginator对数据进行分页

    import { MatPaginator } from '@angular/material/paginator';
...@ViewChild(MatPaginator) paginator: MatPaginator;
...ngAfterViewInit() {this.dataSource.paginator = this.paginator;}
<table mat-table [dataSource]="dataSource">...
</table>
<mat-paginator[pageSizeOptions]="[13, 50, 200]"showFirstLastButtons>
</mat-paginator>

效果如下:

2:尽可能少用或不用ngStyle和 ngClass。无效的css及时清理。ngStyle不仅导致性能问题。还会使样式无法被覆盖。因此要慎用

// less
.grade-background {background: #a1bcd6;
}
.grade-color {color: #37474f;
}// html
<table mat-table [dataSource]="dataSource">...<ng-container matColumnDef="grade"><th mat-header-cell *matHeaderCellDef class="class-unnecessary"> Grade </th><td mat-cell *matCellDef="let element"class="table-cell grade-color class-unnecessary-test"[ngClass]="{'grade-background' : element.grade === 3}"[ngStyle]="{'color': '#DB5C5C'}">{{element.grade}}</td></ng-container>...
</table>

第一次渲染会卡顿,且ngStyle的值未被覆盖

3:使用trackBy,trackBy是angular提供的函数,来告诉angular怎么跟踪数组里的项目。这会减少不必要的DOM的删除和重建

trackByFunction(index: number, row: IDemoRow): string {return row.studentId;
}<table mat-table [dataSource]="dataSource"[trackBy]="trackByFunction">...
</table>
<mat-paginator[pageSizeOptions]="[13, 50, 200]"showFirstLastButtons>
</mat-paginator>

4:但是对于更复杂的表的使用,比如分组管理数据。打开或者关闭某个组的时候,还要操作DOM,那么在以上几种方法的基础上可能还会卡顿

这时候需要利用interval分批操作DOM,能减少卡顿问题

intervalH = window.setInterval(() => {...if (...) {window.clearInterval(intervalH);intervalH = undefined;}...
}, interval);

以上就是几种常用的优化方法。

http://www.yayakq.cn/news/564756/

相关文章:

  • 学校学院网站建设意义wordpress首页如何添加模块
  • 东圃做网站公司网站建设新闻如何更新
  • 企业网站备案费用自助建站 平台
  • 教育网站建设的意义重庆市建设施工安全网站
  • 济南做网站推广有哪些公司盐城seo营销
  • 宁波网站制作计划电商设计专业
  • 网站建设规划书摘要500字网页素材库
  • 查询建设用地规划许可证在哪个网站潍坊市网站建设设计
  • 网站核验单下载搜狗链接提交入口
  • 网站做优化每天一定要更新中小学网站建设建议
  • 网站首页设计分析文安网站建设
  • 做网站推广有哪些公司深圳地图各区分布图
  • 如何将域名和网站绑定域名页面设计期末作业
  • 电商网站开发要求上海做高端网站
  • 什么是网站功能网站的类型有哪几种
  • 罗湖公司网站建设如何做打码网站
  • 做翻译 英文网站网页设计与制作教程杨选辉
  • 公司网站首页设计构想wordpress更新以后进不去了
  • 嘉兴模板建站定制网站佛山建筑公司排名
  • 网站如何建设手机版网页微信文件夹储存在什么位置
  • 游戏ui设计师网站有哪些阿里云1M做网站
  • 该网站受海外服务器保护西安有哪些互联网公司
  • 企业手机网站cms系统腾讯推广联盟
  • wordpress 多个边栏网站建设优化石家庄
  • 做网站年入百万人力资源公司注册
  • 网站打开慢的解决方法seo的含义
  • 大连专业做网站西地那非片能延时多久有副作用吗
  • 手机网站建设的重点步骤郑州专业个人网站建设
  • 网站怎么盈利的个人网页生成器
  • 建筑案例的网站有哪些方面wordpress搜索用户