Angular8 实现table表格表头固定效果
- 作者: 绯梦二十三_
- 来源: 51数据库
- 2021-07-29
最近项目中有个需求,表头固定,内部实现滚动条。除了单个表头,还有多个表头的情况(下一篇中介绍)。
效果图:

html 结构

按区域划分可以分为三个大部分,一共是通过4个table 组合成一个整体的table。
然后通过 col 属性去设定列的宽度,注意:这里的宽度必须要设置为固定值。
表头过滤功能暂时未实现。

水平滚动效果与垂直滚动效果
监听主体table(浅绿色部分)滚动事件,同步上下滚动头部的table (深绿色部分)和 左右滚动左侧固定的table(红色部分中的紫色部分)
代码 1
$(this.tablecontent.nativeelement).on('scroll', (e) => {
$(this.fixedrowwrapper.nativeelement).prop('scrolltop', $(this.tablecontent.nativeelement).prop('scrolltop'));
//方式一 :设置头部固定列table 的滚动条,需要配合less 样式隐藏滚动条(如果不考虑ie9的兼容性,可以使用。less样式参考代码2)
// $(this.tableheader.nativeelement).prop('scrollleft', $(this.tablecontent.nativeelement).prop('scrollleft'))
// 方式二:设置头部固定列table 的margin-left 属性为负值,间接实现了头部固定的列同步向左滚动效果,兼容ie9
$(this.tableheader.nativeelement).css({ marginleft: `${-$(this.tablecontent.nativeelement).prop('scrollleft')}px` })
})
代码 2
.ngx-table__header-inner {
// 隐藏滚动条,页面div 保持横向滚动,但是不支持ie9 ,为了兼容性所以没有使用,ts 中同步滚动
// 而是动态设置 ngx-table__header-inner 的margin-left 实现滚动效果
overflow: -moz-scrollbars-none;
overflow-x: auto;
-ms-overflow-style: none;
&::-webkit-scrollbar {
width: 0 !important;
display: none;
}
}
完整代码地址
github项目地址,需要的可以点击访问 https://github.com/zjinger/ngx-tpr/tree/master/src/app/components/scroll-table
总结
以上所述是小编给大家介绍的angular8 实现table表格表头固定效果,希望对大家有所帮助
推荐阅读
热点文章
Angular中响应式表单的三种更新值方法详析
7
Angularjs实现下拉框联动的示例代码
7
详解AngularJS跨页面传值(ui-router)
2
详解AngularJS1.x学习directive 中‘& ’‘=’ ‘@’符号的区别使用
3
angular2路由切换改变页面title的示例代码
4
Angular2 组件间通过@Input @Output通讯示例
5
Angularjs中ng-repeat的简单实例
3
AngularJS 中ui-view传参的实例详解
4
浅谈Angular路由守卫
4
详解基于Angular4+ server render(服务端渲染)开发教程
4
