项目改造中遇到DIV+CSS实现的table,新需求需要在表格使用单元格合并,网上调查返现CSS display:table实现的table表格,没有单元格的属性和样式,经过一番思考,曲折现实了单元格的合并,即采用正行嵌套一个单独的display:table的DIV,然后在嵌套的表格DIV内部通过控制行列数和行列的高度,实现单元格合并。个人建议全新实现使用
HTML标签即可
一、CSS display属性的表格布局相关属性的解释:
table 此元素会作为块级表格来显示(类似
),表格前后带有换行符。
table-row-group 此元素会作为一个或多个行的分组来显示(类似 )。
table-header-group 此元素会作为一个或多个行的分组来显示(类似 )。
table-footer-group 此元素会作为一个或多个行的分组来显示(类似 )。
table-row 此元素会作为一个表格行显示(类似 )。
table-column-group 此元素会作为一个或多个列的分组来显示(类似 )。
table-column 此元素会作为一个单元格列显示(类似 )
table-cell 此元素会作为一个表格单元格显示(类似 和 | ) table-caption 此元素会作为一个表格标题显示(类似 )
二、示例代码
1、普通表格
XML/HTML Code复制内容到剪贴板
- >
- <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">72812div>
- <div class="table-td">8.0%div>
- div>
- <div class="table-tr">
- <div class="table-td">河南div>
- <div class="table-td">37010div>
- <div class="table-td">8.3%div>
- div>
- <div class="table-tr">
- <div class="table-td">江苏div>
- <div class="table-td">70116div>
- <div class="table-td">8.5%div>
- div>
- div>
- body>
- html>
运行效果
2、列合并实现表格
实现思路:基于display:table的表格实现,没有 |