纯CSS如何实现表头固定?表头固定的实现

本篇文章给大家带来的内容是介绍纯css如何实现表头固定?表头固定的实现。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

纯CSS实现表头固定之所以难,主要在两点:

1、占有最大市场份额的IE6不支持position:fixed。

2、人们想破头都想在一起表格中实现这种效果。

不过外国真的人用纯CSS实现了这种效果,动用了数量惊人的CSS hacks……我觉得,如果搞到代码如此难懂且难扩展,还不如用javascript好了。碰巧今天我也遇到这种需求,换个视角想想,真的搞出来了。

立即学习“前端免费学习笔记(深入)”;

我们知道,CSS是负责表现,HTML是负责结构,同样的结构,换个样式,给人的感觉完全不同,这也说明人的眼睛是很容易受骗。因此前些狂热鼓吹p+CSS的日子里,人们总是想在页面去掉table,用p+span弄出了一个个“table”来。

虽然这种事是不可取,但也告诉我们,table做得的事,通过一些组合我们也能做出来。换个思路来说,既然一个table做不了,就两个吧。

上面的table模拟表头,下面的table模拟带滚动条的部分。在我们继续讲下去之前,我们先明确一下我们的需求吧,要不太抽象了。首先是表格为4*9,每列宽170px,总为680px,滚动条在各浏览器默认为16px,别忘了,width是不包含border在内,四列就有5个纵向的border,宽总长为701px。

然后我们把这个table一分为二,第一个table为表头,第二个table要带滚动条,说明要在其父元素上应用overflow样式,因此它要外套一个p。这个p与第一个table应该是等长的。

不过不用花心思了,我们在它们的外面最套一个p,设置其width为701px,然后把这两个子元素的宽都设为100%就行了。注意,我们在table中显式添加tbody以提高表格的渲染效率。

名称 语法 说明 例子

Simple attribute Selector [attr] 选择具有此属性的元素 blockquote[title] {
color: red }
attribute Value Selector [attr="value"] 选出属性值精确等于给出值的元素 h2[align="left"] {
cursor: hand }
"Begins-with" attribute Value Selector [attr^="value"] 选出属性值以给出值开头的元素 h2[align^="right"] {
cursor: hand }
"Ends-with" attribute Value Selector [attr$="value"] 选出属性值以给出值结尾的元素 p[class$="vml"]{
cursor: hand}
Substring-match attribute Value Selector [attr*="value"] 选出属性值包含给出值的元素 p[class*="grid"]{
float:left}
One-Of-Many Attribute Value Selector [attr~="value"] 原元素的属性值为多个单词,给出值为其中一个。 li[class~="last"]{
padding-left:2em}
Hyphen Attribute Value Selector [attr|="value"] 原元素的属性值等于给出值,或者以给出值加“-”开头 span[lang|="en"]{
color:green}
反选属性值选择器 [attr!="value"] 非标准,jQuery中出现的 span[class!="red"]{
color:green}

表现层部分:

#scrollTable {  width:701px;  border: 1px solid #EB8;/*table没有外围的border,只有内部的td或th有border*/  background: #FF8C00;}  #scrollTable table {  border-collapse:collapse; /*统一设置两个table为细线表格*/} #scrollTable table.thead{ /*表头*/  /*p的第一个子元素*/  width:100%;} #scrollTable table.thead th{/*表头*/  border: 1px solid #EB8;  border-right:#C96;  color:#fff;  background: #FF8C00;/*亮桔黄色*/} #scrollTable p{/*能带滚动条的表身*/  /*p的第二个子元素*/  width:100%;  height:200px;  overflow:auto;/*必需*/} #scrollTable table.tbody{/*能带滚动条的表身的正体*/  width:100%;  border: 1px solid #C96;  border-right:#B74;  color:#666666;  background: #ECE9D8;}#scrollTable table.tbody td{/*能带滚动条的表身的格子*/  border:1px solid #C96;}

运行代码:

          纯CSS实现表头固定          #scrollTable {        width:701px;        border: 1px solid #EB8;/*table没有外围的border,只有内部的td或th有border*/        background: #FF8C00;      }      #scrollTable table {        border-collapse:collapse; /*统一设置两个table为细线表格*/      }      #scrollTable table.thead{ /*表头*/        /*p的第一个子元素*/        width:100%;      }      #scrollTable table.thead th{/*表头*/        border: 1px solid #EB8;        border-right:#C96;        color:#fff;        background: #FF8C00;/*亮桔黄色*/      }      #scrollTable p{/*能带滚动条的表身*/        /*p的第二个子元素*/        width:100%;        height:200px;        overflow:auto;/*必需*/      }      #scrollTable table.tbody{/*能带滚动条的表身的正体*/        width:100%;        border: 1px solid #C96;        border-right:#B74;        color:#666666;        background: #ECE9D8;      }      #scrollTable table.tbody td{/*能带滚动条的表身的格子*/        border:1px solid #C96;      }            

名称 语法 说明 例子

Simple attribute Selector [attr] 选择具有此属性的元素 blockquote[title] {
color: red }
attribute Value Selector [attr="value"] 选出属性值精确等于给出值的元素 h2[align="left"] {
cursor: hand }
"Begins-with" attribute Value Selector [attr^="value"] 选出属性值以给出值开头的元素 h2[align^="right"] {
cursor: hand }
"Ends-with" attribute Value Selector [attr$="value"] 选出属性值以给出值结尾的元素 p[class$="vml"]{
cursor: hand}
Substring-match attribute Value Selector [attr*="value"] 选出属性值包含给出值的元素 p[class*="grid"]{
float:left}
One-Of-Many Attribute Value Selector [attr~="value"] 原元素的属性值为多个单词,给出值为其中一个。 li[class~="last"]{
padding-left:2em}
Hyphen Attribute Value Selector [attr|="value"] 原元素的属性值等于给出值,或者以给出值加“-”开头 span[lang|="en"]{
color:green}
反选属性值选择器 [attr!="value"] 非标准,jQuery中出现的 span[class!="red"]{
color:green}

纯CSS如何实现表头固定?表头固定的实现

发现表头的格子与表身的格子不对齐。这时我们需要动用col标签,col允许我们统一设置tbody中索引值与它相同的td或th的背景色,文字对齐方式与宽度。虽然CSS2.1的相邻选择器与CSS3的子元素过滤伪类能让我们用更精简的方式设置它们,而且是样式与结构分离那种,可惜IE家族总是拖后腿。我们再看一下它们的长度,由于最后一个表格有可能受滚动条挤压而缩短长度,我们保证前三列长度相等就行了,剩余的都分配给最后一个,换言之,最后一个不用设置。另,IE下可以设置滚动条的样式,我们也把玩一翻吧。

//********************略*****************        

//********************略*****************

表现层部分:

#scrollTable {  width:701px;  border: 1px solid #EB8;/*table没有外围的border,只有内部的td或th有border*/  background: #FF8C00;} #scrollTable table {  border-collapse:collapse; /*统一设置两个table为细线表格*/}/*表头 p的第一个子元素**/#scrollTable table.thead{   width:100%;}/*表头*/#scrollTable table.thead th{  border: 1px solid #EB8;  border-right:#C96;  color:#fff;  background: #FF8C00;/*亮桔黄色*/}/*能带滚动条的表身*//*p的第二个子元素*/#scrollTable p{  width:100%;  height:200px;  overflow:auto;/*必需*/  scrollbar-face-color:#EB8;/*那三个小矩形的背景色*/  scrollbar-base-color:#ece9d8;/*那三个小矩形的前景色*/  scrollbar-arrow-color:#FF8C00;/*上下按钮里三角箭头的颜色*/  scrollbar-track-color:#ece9d8;/*滚动条的那个活动块所在的矩形的背景色*/  scrollbar-highlight-color:#800040;/*那三个小矩形左上padding的颜色*/  scrollbar-shadow-color:#800040;/*那三个小矩形右下padding的颜色*/  scrollbar-3dlight-color: #EB8;/*那三个小矩形左上border的颜色*/  scrollbar-darkshadow-Color:#EB8;/*那三个小矩形右下border的颜色*/}/*能带滚动条的表身的正体*/#scrollTable table.tbody{  width:100%;  border: 1px solid #C96;  border-right:#B74;  color:#666666;  background: #ECE9D8;}/*能带滚动条的表身的格子*/#scrollTable table.tbody td{  border:1px solid #C96;}

运行代码:

          纯CSS实现表头固定           #scrollTable {        width:701px;        border: 1px solid #EB8;/*table没有外围的border,只有内部的td或th有border*/        background: #FF8C00;      }      #scrollTable table {        border-collapse:collapse; /*统一设置两个table为细线表格*/      }      /*表头 p的第一个子元素**/      #scrollTable table.thead{         width:100%;      }      /*表头*/      #scrollTable table.thead th{        border: 1px solid #EB8;        border-right:#C96;        color:#fff;        background: #FF8C00;/*亮桔黄色*/      }      /*能带滚动条的表身*/      /*p的第二个子元素*/      #scrollTable p{        width:100%;        height:200px;        overflow:auto;/*必需*/        scrollbar-face-color:#EB8;/*那三个小矩形的背景色*/        scrollbar-base-color:#ece9d8;/*那三个小矩形的前景色*/        scrollbar-arrow-color:#FF8C00;/*上下按钮里三角箭头的颜色*/        scrollbar-track-color:#ece9d8;/*滚动条的那个活动块所在的矩形的背景色*/        scrollbar-highlight-color:#800040;/*那三个小矩形左上padding的颜色*/        scrollbar-shadow-color:#800040;/*那三个小矩形右下padding的颜色*/        scrollbar-3dlight-color: #EB8;/*那三个小矩形左上border的颜色*/        scrollbar-darkshadow-Color:#EB8;/*那三个小矩形右下border的颜色*/      }      /*能带滚动条的表身的正体*/      #scrollTable table.tbody{        width:100%;        border: 1px solid #C96;        border-right:#B74;        color:#666666;        background: #ECE9D8;      }      /*能带滚动条的表身的格子*/      #scrollTable table.tbody td{        border:1px solid #C96;      }            

名称 语法 说明 例子

Simple attribute Selector [attr] 选择具有此属性的元素 blockquote[title] {
color: red }
attribute Value Selector [attr="value"] 选出属性值精确等于给出值的元素 h2[align="left"] {
cursor: hand }
"Begins-with" attribute Value Selector [attr^="value"] 选出属性值以给出值开头的元素 h2[align^="right"] {
cursor: hand }
"Ends-with" attribute Value Selector [attr$="value"] 选出属性值以给出值结尾的元素 p[class$="vml"]{
cursor: hand}
Substring-match attribute Value Selector [attr*="value"] 选出属性值包含给出值的元素 p[class*="grid"]{
float:left}
One-Of-Many Attribute Value Selector [attr~="value"] 原元素的属性值为多个单词,给出值为其中一个。 li[class~="last"]{
padding-left:2em}
Hyphen Attribute Value Selector [attr|="value"] 原元素的属性值等于给出值,或者以给出值加“-”开头 span[lang|="en"]{
color:green}
反选属性值选择器 [attr!="value"] 非标准,jQuery中出现的 span[class!="red"]{
color:green}

1.png

以上就是纯CSS如何实现表头固定?表头固定的实现的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1613302.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 03:32:41
下一篇 2025年12月24日 03:32:52

相关推荐

  • CSS修改placeholder样式的方法介绍(代码示例)

    本篇文章给大家带来的内容是css修改placeholder样式的方法介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 项目用经常遇到修改input的placeholder的颜色的需求,这里来看一下placeholder如何用css设置: 首先来看一下chrome默认的input…

    2025年12月24日 好文分享
    000
  • 纯CSS如何实现柱形图效果?(代码示例)

    本篇文章给大家带来的内容是介绍如何用纯css实现柱形图效果?(代码示例)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 我们都知道,CSS在处理排版之强大,没有做不到,只有想不到。下面我们将一同实现一个柱状图。 先打好一个具体的框架。我们利用无序列表做整体,里面的东西我们根本选择…

    2025年12月24日 好文分享
    000
  • CSS如何绘制一只萌萌哒的大熊猫?(代码示例)

    本篇文章给大家带来的内容是介绍css绘制一只萌萌哒的大熊猫的方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 黑眼圈的大熊猫可谓非常可爱,今天就用CSS实现以下萌萌哒的大熊猫一枚(效果如下): 代码在这儿:https://codepen.io/woshilyy/p……

    2025年12月24日
    000
  • CSS3如何实现聊天气泡效果?(代码示例)

    本篇文章给大家带来的内容是介绍css3巧妙实现聊天气泡效果的方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 前一阵子敢玩的 Mobile 页改版完成了,就之前的页面风格更加扁平化,从暗色系为主背景转到亮色背景,去掉更多的阴影,给用户简约的体验风格,哈哈我不是设计师不过多评价啦…

    2025年12月24日 好文分享
    000
  • ::before有什么作用?::before与:before的区别是什么?

    ::before是什么?有什么作用?本篇文章就给大家::before有什么用,让大家了解::before的简单使用,以及::before与:before的异同点。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 一、::before是什么?有什么作用? 在css中,::before …

    2025年12月24日
    000
  • CSS打印时更改屏幕设计和样式(代码示例)

    本篇文章我们将介绍在打印过程中使用css更改屏幕设计和样式的代码,要在印刷时改变样式,可以在文件中进行样式表的链接的link标签指定media属性,或者在css文件中使用媒体查询。 使用链接标记指定媒体属性时 代码 这是使用链接标记指定media属性的代码。 index.html 立即学习“前端免费…

    2025年12月24日
    200
  • css如何实现图片的旋转展示效果(代码示例)

    本篇文章给大家带来内容是通过代码示例介绍使用css+js实现图片的旋转展示,制作一个手动操作的“无限”照片轮播图。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 下面我们就开始介绍如何实现效果。 1、构建图像轮播框架 首先是HTML。它有点难以阅读,因为我们删除了元素之间的任何空格…

    2025年12月24日
    000
  • 浅谈pointer-events属性是什么?pointer-events属性的使用

    本篇文章给大家带来的内容是浅谈pointer-events属性是什么?pointer-events属性的使用,让大家了解pointer-events属性的相关知识。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们来了解一下pointer-events属性是什么? point…

    2025年12月24日
    000
  • 详解pointer-events属性的使用(代码示例)

    本篇文章给大家带来的内容是详解pointer-events属性的使用(代码示例),让大家了解pointer-events属性可以做什么,有什么效果。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在之前的文章【浅谈pointer-events属性是什么?pointer-events…

    2025年12月24日
    000
  • 通过CSS定位操作的动态元素大小

    这篇文章给大家介绍的是关于通过css定位操作的动态元素大小的内容,有感兴趣的朋友可以看一看,话不多说,我们直接看来看具体的内容。 不使用宽度和高度或JS给体积提供元素的小技巧。 这是一个很简单的技巧,但是很多人不知道。(推荐教程:CSS视频教程) 假设你想制作一个包含每个屏幕100px以外的所有屏幕…

    好文分享 2025年12月24日
    000
  • 如何实现一个特殊的单面css框效果(代码实例)

    随着css3的发展,网络开发的进步已经走向了完美的想象。对于文本和其他用法,css drop-shadow可以实现一个好看的效果框,我们直接来看具体的代码。 这是html部分: Some example text CSS代码 #beauty-boxes{ transition: all 0.5s e…

    2025年12月24日
    000
  • 如何使用css实现进度跟踪条?(代码示例)

    本篇文章给大家分享的内容是关于如何使用css实现进度跟踪条?(代码示例),有需要的朋友可以参考一下。 这是一个关于如何创建一个非常简单的UI小部件的小教程,以告诉用户他们在流程的哪个步骤。 我们将从一小段HTML开始: Site Information Data Source Final Detai…

    2025年12月24日 好文分享
    000
  • css+js如何在幻灯片上添加文字?实现幻灯片的旋转切换(附代码)

    本篇文章给大家带来的内容是介绍css+js如何在幻灯片上添加文字?实现幻灯片的旋转切换(附代码)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在之前的文章【css如何实现幻灯片效果?幻灯片的实现方法】中介绍了实现淡入淡出幻灯片的实现方法,本篇文章就在其基础上去解释如何在幻灯片上…

    2025年12月24日
    000
  • css中inline-block是什么?inline-block布局的使用

    css中inline-block是什么?本篇文章就给大家介绍在css中inline-block是什么意思,让大家了解在css布局中使用inline-block的好处。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们来了解一下inline-block是什么? inline-b…

    2025年12月24日 好文分享
    000
  • float是什么?float属性详解

    float是什么?为什么要使用float?本篇文章就给大家介绍float是什么,让大家了解浮动对布局的作用,清除浮动的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们来了解一下float是什么? float是css的一个定位属性。要了解它的目的和来源,我们可以看一下印…

    2025年12月24日 好文分享
    000
  • 如何在HTML和CSS中使用DIV和span?

    本文将帮助您理解和使用在css和html中如何使用“div”和“span”,并用css对它们进行样式化。使用“div”的主要目的是将主体分成更小的部分,而“span”被用来定义行内一个区域。 一:1.html中使用div 打开记事本并键入基本的HTML结构。它基本上包含HTML内部的主体。 2.将 …

    2025年12月24日
    000
  • html如何添加css样式?行内式、内嵌式、外联式的优缺点

    html如何添加css样式?本篇文章就给大家介绍html添加css样式的三种方法:行内式、内嵌式、外联式的优缺点。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们要了解一下在html中添加css样式的三种方法是什么?它们分别为: 1、使用内联CSS来应用特定元素的规则,即:…

    好文分享 2025年12月24日
    000
  • css的line-clamp属性是什么?如何使用?

    本篇文章给大家带来的内容是介绍css的line-clamp属性是什么?如何使用?有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们来了解一下line-clamp属性是什么? line-clamp属性可以限制在一个块元素显示的文本的行数,为了实现该效果,它需要组合其他外来的We…

    2025年12月24日 好文分享
    000
  • css如何设置列表样式?列表样式的实现

    本篇文章给大家带来的内容是介绍css中list-style属性是什么?如何设置列表样式?有需要的朋友可以参考一下,希望对你们有所帮助。 在前端开发中,我们可以通过css属性来设置不同的列表样式,下面我们来看看css设置列表样式的相关属性。【推荐视频学习:css教程】 list-style属性 lis…

    2025年12月24日 好文分享
    000
  • css如何设置字母间距?字母间距的设置方法

    本篇文章给大家带来的内容是介绍css如何设置字母间距?字母间距的设置方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 其实在css中设置字母间距的方法很简单,只需要使用一个属性就行,这个就是 letter-spacing 属性。 下面我们来了解一下 letter-spacing…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信