js table 表头动态悬浮固定简单实现

当table表单过长时,使用JavaScript实现表头在窗口顶部悬浮,同时表头能跟随横向滚动条同步滑动。通过监听滚动事件,判断滚动距离并复制表头到固定div中,保持格式一致,调整div位置以实现悬浮效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景:

table表单过长过宽,x、y轴都超出了屏幕。下拉表单时,表头距窗口top距离为负时需要将表头悬浮固定在窗口上方,且左右滑动表单时悬浮的表头需要同步滑动

思路:

1、何时悬浮:

获取表头据窗口top的距离L1,获取窗口纵向滚动条下拉的距离L2,若L2 > L1,此时表头悬浮固定。

2、如何悬浮:

因为表格的内容是自由扩展的,所以每一列的列宽是由表头和表内的元素共同决定的,单独把表头拿出来不行,格式会与原表格不一致。最后实现方式:实时监控滚动事件$(window).scroll(function(){},生成div,复制表单至div,获取表头高度给div,'overflow':'hidden',其它部分隐藏。

3、如何跟随横向滚动条左右滑动:

实时监控滚动事件$(window).scroll(function(){},获取横向滚动条距窗口left的距离,赋给表头div 的css样式的position left属性即可。

附上源码:

$(function(){
   var scroll_bar = $("#contentTable");//表格的id
   var bar_head = $("#contentTable thead");//表头
   var bar_height = bar_head.height();//表头高
   var sroll_header= scroll_bar.clone().attr('id','bb');//更改复制的表格id
   $(window).scroll(function(){
      var scroll_top = $(window).scrollTop() - scroll_bar.offset().top;//判断是否到达窗口顶部
      if (scroll_top > 0) {
         $('body').append('<div id="shelter"></div>');//复制的表格所在的容器
         var sl = -Math.max(document.body.scrollLeft, document.documentElement.scrollLeft); // 获取滑动距离
         $("#shelter").css({'height':bar_height + 2,'position':'fixed','top':'0px','left':sl + 'px','overflow':'hidden'});
         sroll_header.appendTo('#shelter');
         $('#shelter').show();

      }else {
         $('#shelter').hide();
      }
   });
});

参考文章:头部固定悬浮table表头(thead)的方法_mingqingyuefeng的博客-优快云博客_table 固定表头

锁定表头固定左边,原生JS原创代码 需要注意的问题: 1.表格的宽度以及表格每一的宽度需要固定(特殊情况除外:当表格数少并且表格总宽度明显小于表格父容器的宽度时,也就是表格不存在自动换行的问题) 2.表格父容器尺寸大小改变时,需要调用 setBoxSize 方法,目的是判断父容器是否出现滚动条 1.1 修正了对IE6、IE7的兼容问题 1.2 修正了固定行、的样式问题 1.3 IE6/IE7浏览器 不启用该功能 1.4 增加了拆分线, 修正了重复生成锁定行的问题以及生成错位的问题, 修正了行、事件无法复制的问题, 增加了IE6/IE7/IE8 启用设置参数(ieLowVersionEnabled: true|false) ,默认不启用, 注:IE6/7/8锁定表头 由于兼容性问题,有些情况下会有一些错位的问题 1.5 增加了 显示/隐藏功能,修正了非IE浏览器下宽错位问题 1.6 修正了当有合并单元格时,锁定单元格错位的问题,修正了表格行数较多时的性能问题 1.7 表格单元格可以不指定宽度(锁定时,取实际的单元格宽度),当单元格的左右两边的borderWidth不一样时,会有一些错位 若单元格宽度是固定的,可以在第3个参数(config)中指定 isFixedSize:true 修正表头未锁定的Bug 1.8 修正表格含有thead时的样式丢失问题,以及行数设置问题,修正thead/tbody行归属问题 1.9 移除tbTopLeft的边框线 修正表格cellpadding/cellspacing的设置问题 修复Firefox下的padding导致的错位问题 修复thead复制没有底部分割线的问题 修复thead复制时无背景色的问题 增加复选框同步功能(如果是JS代码设置复选框选中,需要调用 .setCheckBoxSync()方法) .setCheckBoxSync 方法参数说明:4种参数 1) 复选框控件(html object)数组 2) 复选框控件(html object) 3) 复选框控件ID (string) 4) 空参数(尽量不用空参数)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值