侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

CSS display属性的table表格布局

前端  /  管理员 发布于 7年前   207

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

运行效果

2、列合并实现表格

实现思路:基于display:table的表格实现,没有<table>的rowspan和colspan单元格合并的实现,所以曲折实现,将表格每行单独嵌套一个独立的表格,这样在嵌套的独立表格内部,单元格合并就能通过控制嵌套表格的行数和列数以及单元格的宽高来实现

XML/HTML Code复制内容到剪贴板
  1. <!DOCTYPE html>  
  2. <html>  
  3. <head>  
  4. <meta charset="UTF-8">  
  5. <title>基于display列合并表格</title>  
  6. <style type="text/css">  
  7. .table, .table * {margin: 0 auto; padding: 0;font-size: 14px;font-family: Arial, 宋体, Helvetica, sans-serif;}   
  8. .table {display: table; width: 80%; border-collapse: collapse;}   
  9.   
  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;background-color:#E5E5E5;}   
  12. .table-td {display: table-cell; height: 100%;}   
  13.   
  14. .sub-table {width: 100%;height: 100%;display: table;}   
  15. .sub-table-tr {display: table-row; height: 100%;}   
  16. .sub-table-td {display: table-cell; height: 100%;border: 1px solid gray; text-align: center;vertical-align: middle;}   
  17.   
  18. </style>  
  19. </head>  
  20. <body>  
  21.   
  22. <div class="table">  
  23.     <div class="table-tr">  
  24.         <div class="table-td">  
  25.             <div class="sub-table">  
  26.                 <div class="sub-table-tr">  
  27.                     <div class="table-th" style="width: 40%;">省份/直辖市</div>  
  28.                     <div class="table-th" style="width: 30%;">GDP(亿元)</div>  
  29.                     <div class="table-th" style="width: 30%;">增长率</div>  
  30.                 </div>  
  31.             </div>  
  32.         </div>  
  33.     </div>  
  34.     <div class="table-tr">  
  35.         <div class="table-td">  
  36.             <div class="sub-table">  
  37.                 <div class="sub-table-tr">  
  38.                     <div class="sub-table-td" style="width: 40%;">广东</div>  
  39.                     <div class="sub-table-td" style="width: 30%;">72812</div>  
  40.                     <div class="sub-table-td" style="width: 30%;">8.0%</div>  
  41.                 </div>  
  42.             </div>  
  43.         </div>  
  44.     </div>  
  45.     <div class="table-tr">  
  46.         <div class="table-td">  
  47.             <div class="sub-table">  
  48.                 <div class="sub-table-tr">  
  49.                     <div class="sub-table-td" style="width: 40%;">河南</div>  
  50.                     <div class="sub-table-td" style="width: 30%;">37010</div>  
  51.                     <div class="sub-table-td" style="width: 30%;">8.3%</div>  
  52.                 </div>  
  53.             </div>  
  54.         </div>  
  55.     </div>  
  56.     <div class="table-tr">  
  57.         <div class="table-td">  
  58.             <div class="sub-table">  
  59.                 <div class="sub-table-tr">  
  60.                     <div class="sub-table-td" style="width: 40%;">江苏</div>  
  61.                     <div class="sub-table-td" style="width: 30%;">70116</div>  
  62.                     <div class="sub-table-td" style="width: 30%;">8.5%</div>  
  63.                 </div>  
  64.             </div>  
  65.         </div>  
  66.     </div>  
  67.     <div class="table-tr">  
  68.   

  • 上一条:
    使用CSS媒体查询创建响应式布局教程
    下一条:
    你应该知道的3个CSS技巧
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客