使用div实现table效果

本文介绍了如何使用CSS的display属性模拟table布局,包括如何实现单元格合并。详细讲述了table、table-row、table-cell等display属性的作用,并提供了普通表格、列合并和行合并的示例代码。
摘要由CSDN通过智能技术生成
  1. 项目改造中遇到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、普通表格

  2. <!DOCTYPE html>  
  3. <html>  
  4. <head>  
  5. <meta charset="UTF-8">  
  6. <title>display普通表格</title>  
  7. <style type="text/css">  
  8. .table, .table * {margin: 0 auto; padding: 0;font-size: 14px;font-family: Arial, 宋体, Helvetica, sans-serif;}   
  9. .table {display: table; width: 80%; border-collapse: collapse;}   
  10. .table-tr {display: table-row; height: 30px;}   
  11. .table-th {display: table-cell;font-weight: bold;height: 100%;border: 1px solid gray;text-align: center;vertical-align: middle;}   
  12. .table-td {display: table-cell; height: 100%;border: 1px solid gray; text-align: center;vertical-align: middle;}   
  13. </style>  
  14. </head>  
  15. <body>  
  16.     <div class="table">  
  17.         <div class="table-tr">  
  18.             <div class="table-th">省份/直辖市</div>  
  19.             <div class="table-th">GDP(亿元)</div>  
  20.             <div class="table-th">增长率</div>  
  21.         </div>  
  22.         <div class="table-tr">  
  23.             <div class="table-td">广东</div>  
  24.             <div class="table-td">72812</div>  
  25.             <div class="table-td">8.0%</div>  
  26.         </div>  
  27.         <div class="table-tr">  
  28.             <div class="table-td">河南</div>  
  29.             <div class="table-td">37010</div>  
  30.             <div class="table-td">8.3%</div>  
  31.         </div>  
  32.         <div class="table-tr">  
  33.             <div class="table-td">江苏</div>  
  34.             <div class="table-td">70116</div>  
  35.             <div class="table-td">8.5%</div>  
  36.         </div>  
  37.     </div>  
  38. </body>  
  39. </html>   

2、列合并实现表格

实现思路:基于display:table的表格实现,没有<ta

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值