CSS 表格

使用 CSS 可以极大地改善 HTML 表格的外观:

Company Contact Address City
Alibaba Ma Yun No. 699, Wangshang Road, Binjiang District Hangzhou
APPLE Tim Cook 1 Infinite Loop Cupertino, CA 95014 Cupertino
BAIDU Li YanHong Lixiang guoji dasha,No 58, beisihuanxilu Beijing
Canon Tsuneji Uchida One Canon Plaza Lake Success, NY 11042 New York
Google Larry Page 1600 Amphitheatre Parkway Mountain View, CA 94043 Mountain View
HUAWEI Ren Zhengfei Putian Huawei Base, Longgang District Shenzhen
Microsoft Bill Gates 15700 NE 39th St Redmond, WA 98052 Redmond
Nokia Olli-Pekka Kallasvuo P.O. Box 226, FIN-00045 Nokia Group Helsinki
SONY Kazuo Hirai Park Ridge, NJ 07656 Park Ridge
Tencent Ma Huateng Tencent Building, High-tech Park, Nanshan District Shenzhen

表格边框

如需在 CSS 中设置表格边框,请使用 border 属性。

下例为 <table><th><td> 元素规定了黑色边框:

trycss_table_border_iframe.htm

实例

  1. table, th, td {
  2. border: 1px solid black;
  3. }

注意:上例中的表格拥有双边框。这是因为 table 和 <th><td> 元素都有单独的边框。

全宽表格

在某些情况下,上表似乎很小。如果您需要一个可以覆盖整个屏幕(全宽)的表格,请为 <table> 元素添加 width: 100%:

实例

  1. table {
  2. width: 100%;
  3. }

双边框

请注意上面的表格有双边框。这是因为表格和 th、td 元素都有单独的边框。

如需删除双边框,请看下面的例子。

合并表格边框

border-collapse 属性设置是否将表格边框折叠为单一边框:

trycss_table_border-collapse_iframe.htm

实例

  1. table {
  2. border-collapse: collapse;
  3. }
  4. table, th, td {
  5. border: 1px solid black;
  6. }

如果只希望表格周围有边框,则仅需为 <table> 指定 border 属性:

trycss_table_border2_iframe.htm

实例

  1. table {
  2. border: 1px solid black;
  3. }

表格宽度和高度

表格的宽度和高度由 widthheight 属性定义。

下例将表的宽度设置为 100%,将 <th> 元素的高度设置为 50px:

trycss_table_width_iframe.htm

实例

  1. table {
  2. width: 100%;
  3. }
  4. th {
  5. height: 50px;
  6. }

要创建仅占页面一半的表,请使用 width: 50%:

实例

  1. table {
  2. width: 50%;
  3. }
  4. th {
  5. height: 70px;
  6. }

水平对齐

text-align 属性设置 <th><td> 中内容的水平对齐方式(左、右或居中)。

默认情况下,<th> 元素的内容居中对齐,而 <td> 元素的内容左对齐。

要使 <td> 元素的内容也居中对齐,请使用 text-align: center

css_table_align_center.htm

实例

  1. th {
  2. text-align: center;
  3. }

下例使 <th> 元素中的文本左对齐:

trycss_table_align_iframe.htm

实例

  1. th {
  2. text-align: left;
  3. }

垂直对齐

vertical-align 属性设置 <th><td> 中内容的垂直对齐方式(上、下或居中)。

默认情况下,表中内容的垂直对齐是居中(<th><td> 元素都是)。

下例将 <td> 元素的垂直文本对齐方式设置为下对齐:

trycss_table_vertical-align_iframe.htm

实例

  1. td {
  2. height: 50px;
  3. vertical-align: bottom;
  4. }

表格内边距

如需控制边框和表格内容之间的间距,请在 <td><th> 元素上使用 padding 属性:

trycss_table_border-padding_iframe.htm

实例

  1. th, td {
  2. padding: 15px;
  3. text-align: left;
  4. }

水平分隔线

css_table_border_divider.htm

<th><td> 添加 border-bottom 属性,以实现水平分隔线:

实例

  1. th, td {
  2. border-bottom: 1px solid #ddd;
  3. }

可悬停表格

<tr> 元素上使用 :hover 选择器,以突出显示鼠标悬停时的表格行:

css_table_hover.htm

实例

  1. tr:hover {background-color: #f5f5f5;}

条状表格

css_table_striped.htm

为了实现斑马纹表格效果,请使用 nth-child() 选择器,并为所有偶数(或奇数)表行添加background-color

实例

  1. tr:nth-child(even) {background-color: #f2f2f2;}

表格颜色

下例指定了 <th> 元素的背景颜色和文本颜色:

css_table_color.htm

实例

  1. th {
  2. background-color: #4CAF50;
  3. color: white;
  4. }

响应式表格

如果屏幕太小而无法显示全部内容,则响应式表格会显示水平滚动条:

css_table_responsive.htm

<table> 元素周围添加带有 overflow-x:auto 的容器元素(例如 <div>),以实现响应式效果:

实例

  1. <div style="overflow-x:auto;">
  2. <table>
  3. ... table content ...
  4. </table>
  5. </div>

注释:在 OS X Lion(在 Mac 上)中,滚动条默认情况下是隐藏的,并且仅在使用时显示(即使设置了 “overflow:scroll”)。

更多实例

做一张花式表格

本例演示如何创建花式表格。

  1. <head>
  2. <style>
  3. #customers {
  4. font-family: Arial, Helvetica, sans-serif;
  5. border-collapse: collapse;
  6. width: 100%;
  7. }
  8. #customers td, #customers th {
  9. border: 1px solid #ddd;
  10. padding: 8px;
  11. }
  12. #customers tr:nth-child(even){background-color: #f2f2f2;}
  13. #customers tr:hover {background-color: #ddd;}
  14. #customers th {
  15. padding-top: 12px;
  16. padding-bottom: 12px;
  17. text-align: left;
  18. background-color: #4CAF50;
  19. color: white;
  20. }
  21. </style>
  22. </head>
  23. <body>
  24. <table id="customers">
  25. <tr>
  26. <th>Company</th>
  27. <th>Contact</th>
  28. <th>Address</th>
  29. <th>City</th>
  30. </tr>
  31. <tr>
  32. <td>Alibaba</td>
  33. <td>Ma Yun</td>
  34. <td>No. 699, Wangshang Road, Binjiang District</td>
  35. <td>Hangzhou</td>
  36. </tr>
  37. <tr>
  38. <td>APPLE</td>
  39. <td>Tim Cook</td>
  40. <td>1 Infinite Loop Cupertino, CA 95014</td>
  41. <td>Cupertino</td>
  42. </tr>
  43. <tr>
  44. <td>BAIDU</td>
  45. <td>Li YanHong</td>
  46. <td>Lixiang guoji dasha,No 58, beisihuanxilu</td>
  47. <td>Beijing</td>
  48. </tr>
  49. <tr>
  50. <td>Canon</td>
  51. <td>Tsuneji Uchida</td>
  52. <td>One Canon Plaza Lake Success, NY 11042</td>
  53. <td>New York</td>
  54. </tr>
  55. <tr>
  56. <td>Google</td>
  57. <td>Larry Page</td>
  58. <td>1600 Amphitheatre Parkway Mountain View, CA 94043</td>
  59. <td>Mountain View</td>
  60. </tr>
  61. <tr>
  62. <td>HUAWEI</td>
  63. <td>Ren Zhengfei</td>
  64. <td>Putian Huawei Base, Longgang District</td>
  65. <td>Shenzhen</td>
  66. </tr>
  67. <tr>
  68. <td>Microsoft</td>
  69. <td>Bill Gates</td>
  70. <td>15700 NE 39th St Redmond, WA 98052</td>
  71. <td>Redmond</td>
  72. </tr>
  73. <tr>
  74. <td>Nokia</td>
  75. <td>Olli-Pekka Kallasvuo</td>
  76. <td>P.O. Box 226, FIN-00045 Nokia Group</td>
  77. <td>Helsinki</td>
  78. </tr>
  79. <tr>
  80. <td>SONY</td>
  81. <td>Kazuo Hirai</td>
  82. <td>Park Ridge, NJ 07656</td>
  83. <td>Park Ridge</td>
  84. </tr>
  85. <tr>
  86. <td>Tencent</td>
  87. <td>Ma Huateng</td>
  88. <td>Tencent Building, High-tech Park, Nanshan District</td>
  89. <td>Shenzhen</td>
  90. </tr>
  91. </table>
  92. </body>

设置表格标题的位置

本例演示了如何放置表格标题。

  1. <head>
  2. <style>
  3. table, td, th {
  4. border: 1px solid black;
  5. }
  6. caption {
  7. caption-side: bottom;
  8. }
  9. </style>
  10. </head>
  11. <body>
  12. <table>
  13. <caption>Table 1.1 Customers</caption>
  14. <tr>
  15. <th>Company</th>
  16. <th>Contact</th>
  17. <th>City</th>
  18. </tr>
  19. <tr>
  20. <td>Alibaba</td>
  21. <td>Ma Yun</td>
  22. <td>Hangzhou</td>
  23. </tr>
  24. <tr class="alt">
  25. <td>Hangzhou</td>
  26. <td>Tim Cook</td>
  27. <td>Cupertino</td>
  28. </tr>
  29. <tr>
  30. <td>BAIDU</td>
  31. <td>Li YanHong</td>
  32. <td>Beijing</td>
  33. </tr>
  34. <tr class="alt">
  35. <td>HUAWEI</td>
  36. <td>Ren Zhengfei</td>
  37. <td>Shenzhen</td>
  38. </tr>
  39. <tr>
  40. <td>Tencent</td>
  41. <td>Ma Huateng</td>
  42. <td>Shenzhen</td>
  43. </tr>
  44. </table>
  45. </body>

CSS 表格属性

属性 描述
border 简写属性。在一条声明中设置所有边框属性。
border-collapse 规定是否应折叠表格边框。
border-spacing 规定相邻单元格之间的边框的距离。
caption-side 规定表格标题的位置。
empty-cells 规定是否在表格中的空白单元格上显示边框和背景。
table-layout 设置用于表格的布局算法。