天天看点

table实现表头固定table实现表头固定

table实现表头固定

HTML

<div style="width: 800px;">
     <div class="table-head">
     <table>
         <colgroup>
             <col style="width: 80px;" />
             <col />
         </colgroup>
         <thead>
             <tr><th>序号</th><th>内容</th></tr>
         </thead>
     </table>
     </div>
     <div class="table-body">
     <table>
         <colgroup><col style="width: 80px;" /><col /></colgroup>
         <tbody>
             <tr><td>a</td><td>我只是用来测试的</td></tr>
             <tr><td>b</td><td>我只是用来测试的</td></tr>
             <tr><td>c</td><td>我只是用来测试的</td></tr>
             <tr><td>d</td><td>我只是用来测试的</td></tr>
             <tr><td>e</td><td>我只是用来测试的</td></tr>
         </tbody>
     </table>
     </div>
 </div>
           

CSS

.table-head{padding-right:17px;background-color:#999;color:#000;}
 .table-body{width:100%; height:300px;overflow-y:scroll;}
 .table-head table,.table-body table{width:100%;}
 .table-body table tr:nth-child(2n+1){background-color:#f2f2f2;}
           

备注

其实关键之处在于

1、使用了colgroup标签,来对上下两个表格的列宽进行了定义,让他们保持一致。

2、上边的div .table-head添加了样式padding-right:17px,这个宽度是为了保证跟下边的div .table-body的滚动条保持一致,同时下边的表格.table-body添加了样式overflow-y:scroll;

只要保证上述两点的话,你也可以做出固定表头的表格来,同时不会发生上下的列不对齐的问题,屡试不爽!