项目改造中遇到DIV+CSS实现的table,新需求需要在表格使用单元格合并,网上调查返现CSS display:table实现的table表格,没有单元格的属性和样式,经过一番思考,曲折现实了单元格的合并,即采用正行嵌套一个单独的display:table的DIV,然后在嵌套的表格DIV内部通过控制行列数和行列的高度,实现单元格合并。个人建议全新实现使用<table> HTML标签即可
一、CSS display属性的表格布局相关属性的解释:
table 此元素会作为块级表格来显示(类似 <table>),表格前后带有换行符。
table-row-group 此元素会作为一个或多个行的分组来显示(类似 <tbody>)。
table-header-group 此元素会作为一个或多个行的分组来显示(类似 <thead>)。
table-footer-group 此元素会作为一个或多个行的分组来显示(类似 <tfoot>)。
table-row 此元素会作为一个表格行显示(类似 <tr>)。
table-column-group 此元素会作为一个或多个列的分组来显示(类似 <colgroup>)。
table-column 此元素会作为一个单元格列显示(类似 <col>)
table-cell 此元素会作为一个表格单元格显示(类似 <td> 和 <th>)
table-caption 此元素会作为一个表格标题显示(类似 <caption>)
二、示例代码
1、普通表格
XML/HTML Code复制内容到剪贴板
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="UTF-8">
- <title>display普通表格</title>
- <style type="text/css">
- .table, .table * {margin: 0 auto; padding: 0;font-size: 14px;font-family: Arial, 宋体, Helvetica, sans-serif;}
- .table {display: table; width: 80%; border-collapse: collapse;}
- .table-tr {display: table-row; height: 30px;}
- .table-th {display: table-cell;font-weight: bold;height: 100%;border: 1px solid gray;text-align: center;vertical-align: middle;background-color:#E5E5E5;}
- .table-td {display: table-cell; height: 100%;border: 1px solid gray; text-align: center;vertical-align: middle;}
- </style>
- </head>
- <body>
- <div class="table">
- <div class="table-tr">
- <div class="table-th">省份/直辖市</div>
- <div class="table-th">GDP(亿元)</div>
- <div class="table-th">增长率</div>
- </div>
- <div class="table-tr">
- <div class="table-td">广东</div>
- <div class="table-td">72812</div>
- <div class="table-td">8.0%</div>
- </div>
- <div class="table-tr">
- <div class="table-td">河南</div>
- <div class="table-td">37010</div>
- <div class="table-td">8.3%</div>
- </div>
- <div class="table-tr">
- <div class="table-td">江苏</div>
- <div class="table-td">70116</div>
- <div class="table-td">8.5%</div>
- </div>
- </div>
- </body>
- </html>
运行效果

2、列合并实现表格
实现思路:基于display:table的表格实现,没有<table>的rowspan和colspan单元格合并的实现,所以曲折实现,将表格每行单独嵌套一个独立的表格,这样在嵌套的独立表格内部,单元格合并就能通过控制嵌套表格的行数和列数以及单元格的宽高来实现
XML/HTML Code复制内容到剪贴板
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="UTF-8">
- <title>基于display列合并表格</title>
- <style type="text/css">
- .table, .table * {margin: 0 auto; padding: 0;font-size: 14px;font-family: Arial, 宋体, Helvetica, sans-serif;}
- .table {display: table; width: 80%; border-collapse: collapse;}
-
- .table-tr {display: table-row; height: 30px;}
- .table-th {display: table-cell;font-weight: bold;height: 100%;border: 1px solid gray;text-align: center;vertical-align: middle;background-color:#E5E5E5;}
- .table-td {display: table-cell; height: 100%;}
-
- .sub-table {width: 100%;height: 100%;display: table;}
- .sub-table-tr {display: table-row; height: 100%;}
- .sub-table-td {display: table-cell; height: 100%;border: 1px solid gray; text-align: center;vertical-align: middle;}
-
- </style>
- </head>
- <body>
-
- <div class="table">
- <div class="table-tr">
- <div class="table-td">
- <div class="sub-table">
- <div class="sub-table-tr">
- <div class="table-th" style="width: 40%;">省份/直辖市</div>
- <div class="table-th" style="width: 30%;">GDP(亿元)</div>
- <div class="table-th" style="width: 30%;">增长率</div>
- </div>
- </div>
- </div>
- </div>
- <div class="table-tr">
- <div class="table-td">
- <div class="sub-table">
- <div class="sub-table-tr">
- <div class="sub-table-td" style="width: 40%;">广东</div>
- <div class="sub-table-td" style="width: 30%;">72812</div>
- <div class="sub-table-td" style="width: 30%;">8.0%</div>
- </div>
- </div>
- </div>
- </div>
- <div class="table-tr">
- <div class="table-td">
- <div class="sub-table">
- <div class="sub-table-tr">
- <div class="sub-table-td" style="width: 40%;">河南</div>
- <div class="sub-table-td" style="width: 30%;">37010</div>
- <div class="sub-table-td" style="width: 30%;">8.3%</div>
- </div>
- </div>
- </div>
- </div>
- <div class="table-tr">
- <div class="table-td">
- <div class="sub-table">
- <div class="sub-table-tr">
- <div class="sub-table-td" style="width: 40%;">江苏</div>
- <div class="sub-table-td" style="width: 30%;">70116</div>
- <div class="sub-table-td" style="width: 30%;">8.5%</div>
- </div>
- </div>
- </div>
- </div>
- <div class="table-tr">
- <div class="table-td">
- <div class="sub-table">
- <div class="sub-table-tr">
- <div class="sub-table-td" style="width: 70%;">各省/直辖市GDP平均增长率</div>
- <div class="sub-table-td" style="width: 30%;">8.26%</div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </body>
- </html>
运行效果

3、行合并表格
行合并的实现思路:与列合并的实现思路类似,将有单元格合并的列单独嵌套一个display为table的DIV,高度=单行高*单元格合并数目的倍数,同行的其他列同样均单独嵌套DIV,实例代码如下
XML/HTML Code复制内容到剪贴板
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="UTF-8">
- <title>基于display的行合并表格</title>
- <style type="text/css">
- .table, .table * {margin: 0 auto; padding: 0;font-size: 14px;font-family: Arial, 宋体, Helvetica, sans-serif;}
- .table {display: table; width: 80%; border-collapse: collapse;}
-
- .table-tr {display: table-row; height: 30px;}
- .table-th {display: table-cell;font-weight: bold;height: 100%;border: 1px solid gray;text-align: center;vertical-align: middle;background-color:#E5E5E5;}
- .table-td {display: table-cell; height: 100%;}
-
- .sub-table {width: 100%;height: 100%;display: table;}
- .sub-table-tr {display: table-row; height: 100%;}
- .sub-table-td {display: table-cell; height: 100%;border: 1px solid gray; text-align: center;vertical-align: middle;}
-
- </style>
- </head>
- <body>
-
- <div class="table">
- <div class="table-tr">
- <div class="table-td">
- <div class="sub-table">
- <div class="sub-table-tr">
- <div class="table-th" style="width: 40%;">省份/直辖市</div>
- <div class="table-th" style="width: 30%;">GDP(亿元)</div>
- <div class="table-th" style="width: 30%;">增长率</div>
- </div>
- </div>
- </div>
- </div>
- <div class="table-tr">
- <div class="table-td">
- <div class="sub-table">
- <div class="sub-table-tr">
- <div class="sub-table-td" style="width: 40%;">广东</div>
- <div class="sub-table-td" style="width: 30%;">72812</div>
- <div class="sub-table-td" style="width: 30%;">8.0%</div>
- </div>
- </div>
- </div>
- </div>
- <div class="table-tr" style="height:60px;">
- <div class="table-td">
- <div class="sub-table">
- <div class="sub-table-tr">
- <div class="sub-table-td" style="width: 40%; border: none;">
- <div class="sub-table">
- <div class="sub-table-tr" style="height:50%;">
- <div class="sub-table-td" style="width: 100%; height:50%;">
- 河南
- </div>
- </div>
- <div class="sub-table-tr" style="height:50%;">
- <div class="sub-table-td" style="width: 100%; height:50%;">
- 江苏
- </div>
- </div>
- </div>
- </div>
- <div class="sub-table-td" style="width: 30%;border: none;">
- <div class="sub-table">
- <div class="sub-table-tr" style="height:50%;">
- <div class="sub-table-td" style="width: 100%; height:50%;">
- 37010
- </div>
- </div>
- <div class="sub-table-tr" style="height:50%;">
- <div class="sub-table-td" style="width: 100%; height:50%;">
- 70116
- </div>
- </div>
- </div>
-
- </div>
-
- <div class="sub-table-td" style="width: 30%;border: none;">
- <div class="sub-table">
- <div class="sub-table-tr">
- <<
CSS样式分离之再分离达到精简与重用
无论是CSS的分离还是js的分离,其主要作用之一就是精简与重用,CSS本身就代表着精简与重用,CSS样式分离,我一般指的是“以单独的CSS文件将CSS样式分离出来”,此处的重用多针对不同页面的重用,就是说,一个样式文件,可以多个页面使用,这对于一些公共样式的重构是很有
收藏 0赞 0分享
CSS属性behavior的语法使用说明
在进行CSS网页布局的时候,我们经遇到刷新要保留表单里内容的时候,习惯的做法使用cookie,但是那样做实在是很麻烦,css中的behavior就为我们很好的解决了这个问题。今天jb51.net就向大家介绍CSS属性behavior的语法
收藏 0赞 0分享
最常见IE的Bug及其fix修复方法
Internet Explorer – Web程序员的毒药。在IE上开发时间中有超过60%的时间是花在和IE的bug进行搏斗,让你的开发生产率严重下降。下面是一个教程,告诉你9个IE上最常见的BUG以及如何解决它们。
收藏 0赞 0分享
CSS常用浏览器兼容调整小结
用CSS+DIV来写网站代码的好处显而易见,这里不多说了,但由于不同浏览器对CSS的解释不统一,造成不同浏览器下页面错位的现象十分常见……
收藏 0赞 0分享
DIV+CSS 浏览器兼容性小结
在网站设计的时候,应该注意css样式兼容不同浏览器问题,特别是对完全使用DIV CSS设计的网,就应该更注意IE6 IE7 FF对CSS样式的兼容,不然,你的网乱可能出去不想出现的效果!
收藏 0赞 0分享
div+css 布局常识 8问
CSSer与其他IT职位一样,在找工作的时候,都会面临着面试官提出的问题,或者给出的试卷。今天jb51.net收集了常见的8条面试题目,希望对您有所帮助。
收藏 0赞 0分享
css 解决表格边框不显示的问题
在 IE6 中,当表格单元格中的数据为空时,边框是不显示的,在IE8中是会显示的,怎样解决这个不兼容的问题呢。
收藏 0赞 0分享
查看更多