CSS3实现响应式数据表格

jerry CSS 2015年08月20日 收藏

设计响应式页面的时候,最难的是表格table的处理,table作为数据表格设计不可缺少的元素,在数据应用项目中起着重要的作用,但是要想让表格适应各种屏幕还真有点麻烦。本文将用实例给大家演示如何使用CSS3来实现的响应式数据表格。

当屏幕足够小(如手机屏幕),以至于小于表格的最小宽度,如果不做响应式处理,那么将会出现水平滚动条,需要手动移动放大来查看超出屏幕的部分,这样体验很差。我们的解决办法是使用CSS @media queries来检测屏幕尺寸,当屏幕尺寸足够小的时候,重新布局table表格。

HTML

假设我们有一个如下的数据表格,当然它可能有更多的列,文中代码只用了3列。

  1. <table>
  2. <thead>
  3. <tr>
  4. <th>姓名</th>
  5. <th>性别</th>
  6. <th>出生年月</th>
  7. </tr>
  8. </thead>
  9. <tbody>
  10. <tr>
  11. <td>蒋介</td>
  12. <td></td>
  13. <td>1998.2.5</td>
  14. </tr>
  15. <tr>
  16. <td>许维</td>
  17. <td></td>
  18. <td>1998.2.1</td>
  19. </tr>
  20. </tbody>
  21. </table>

CSS3

首先,我们使用一些简单的css代码就可以呈现一个基本的table表格,css代码并没有特别的地方。

  1. table {
  2. width: 100%;
  3. border-collapse: collapse;
  4. }
  5. tr:nth-of-type(odd) {
  6. background: #eee;
  7. }
  8. th {
  9. background: #333;
  10. color: white;
  11. font-weight: bold;
  12. }
  13. td, th {
  14. padding: 6px;
  15. border: 1px solid #ccc;
  16. text-align: left;
  17. }

这个时候,我们使用电脑浏览器打开页面,发现展示了一个简单的表格,随着浏览器窗口的缩小,表格宽度会变小,但当浏览器窗口足够小的时候,问题就来了,表格宽度由于表格单元的内容撑着无法再变小,从而出项横向滚动条的情况,那么下面的css3代码提供了解决方案。

我们要做的是,使用css3的@media检测到屏幕尺寸,将表格元素设置为block块状,并且隐藏表头,将td设置下边框看起来跟一行行的一样。最后我们使用css3的:before { content: "姓名"; }生成每行对应的标签定义,这样就能知道每行数据的意义。

  1. @media
  2. only screen and (max-width: 760px),
  3. (min-device-width: 768px) and (max-device-width: 1024px) {
  4. /* Force table to not be like tables anymore */
  5. table, thead, tbody, th, td, tr {
  6. display: block;
  7. }
  8. thead tr {
  9. position: absolute;
  10. top: -9999px;
  11. left: -9999px;
  12. }
  13. tr { border: 1px solid #ccc; }
  14. td {
  15. /* Behave like a "row" */
  16. border: none;
  17. border-bottom: 1px solid #eee;
  18. position: relative;
  19. padding-left: 50%;
  20. }
  21. td:before {
  22. /* Now like a table header */
  23. position: absolute;
  24. /* Top/left values mimic padding */
  25. top: 6px;
  26. left: 6px;
  27. width: 45%;
  28. padding-right: 10px;
  29. white-space: nowrap;
  30. }
  31. /*
  32. Label the data
  33. */
  34. td:nth-of-type(1):before { content: "姓名"; }
  35. td:nth-of-type(2):before { content: "性别"; }
  36. td:nth-of-type(3):before { content: "出生年月"; }
  37. }

现在你用手机打开页面,你会发现表格的布局变了,它是这样的:

当然,本例也不是最佳解决方案,有兴趣的朋友可以参照bootstrap关于响应式表格的处理。

下载地址