编程笔记 html5&css&js 050 CSS表格2-1

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

一、表格边框

如需在 CSS 中设置表格边框,请使用 border 属性。
下例为 <table>、<th><td> 元素规定了黑色边框:

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

二、全宽表格

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

table {
  width: 100%;
}

双边框
请注意上面的表格有双边框。这是因为表格和 th、td 元素都有单独的边框。
如需删除双边框,请看下面的例子。

三、合并表格边框

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

table {
  border-collapse: collapse;
}
table, th, td {
  border: 1px solid black;
}

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

table {
  border: 1px solid black;
}

四、表格宽度和高度

表格的宽度和高度由 width 和 height 属性定义。
下例将表的宽度设置为 100%,将 <th> 元素的高度设置为 50px:

table {
  width: 100%;
}
th {
  height: 50px;
}

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

table {
  width: 50%;
}
th {
  height: 70px;
}

五、水平对齐

text-align 属性设置 <th><td> 中内容的水平对齐方式(左、右或居中)。
默认情况下,<th> 元素的内容居中对齐,而 <td> 元素的内容左对齐。
要使 <td> 元素的内容也居中对齐,请使用 text-align: center

th {
  text-align: center;
}

文本左对齐:

th {
  text-align: left;
}

六、垂直对齐

vertical-align 属性设置 <th><td> 中内容的垂直对齐方式(上、下或居中)。默认情况下,表中内容的垂直对齐是居中(<th><td> 元素都是)。下例将 <td> 元素的垂直文本对齐方式设置为下对齐:

td {
  height: 50px;
  vertical-align: bottom;
}

七、表格内边距

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

th, td {
  padding: 15px;
  text-align: left;
}

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

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

八、可悬停表格

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

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

九、条状表格

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

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

十、表格颜色

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

th {
  background-color: #4CAF50;
  color: white;
}

十一、响应式表格

如果屏幕太小而无法显示全部内容,则响应式表格会显示水平滚动条:
<table> 元素周围添加带有 overflow-x:auto 的容器元素(例如 <div>),以实现响应式效果:

<div style="overflow-x:auto;">
<table>
... table content ...
</table>
</div>

十二、CSS 表格属性

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

十三、练习

<!DOCTYPE html>
<html lang="zh-cn">
   <head>
      <title>css列表 编程笔记 html5&css&js</title>
      <meta charset="utf-8" />
      <style>
         body {
            color: cyan;
            background-color: teal;
         }
         #customers {
            border-collapse: collapse;
            width: 90%;
            margin: 50px auto;
         }
         #customers td,
         #customers th {
            border: 1px solid #ddd;
            padding: 8px;
         }
         #customers tr:nth-child(even) {
            background-color: #f2f2f2;
         }
         #customers tr:hover {
            background-color: #ddd;
         }
         #customers th {
            padding-top: 12px;
            padding-bottom: 12px;
            text-align: left;
            background-color: #4caf50;
            color: white;
         }
      </style>
   </head>
   <body>
      <table id="customers">
         <tr>
            <th>课节</th>
            <th>星期一</th>
            <th>星期二</th>
            <th>星期三</th>
            <th>星期四</th>
            <th>星期五</th>
            <th>星期六</th>
            <th>星期日</th>
         </tr>
         <tr>
            <td>第一节</td>
            <td>语文</td>
            <td>数学</td>
            <td>科学</td>
            <td>外语</td>
            <td>数学</td>
            <td></td>
            <td></td>
         </tr>
         <tr>
            <td>第二节</td>
            <td>语文</td>
            <td>数学</td>
            <td>科学</td>
            <td>外语</td>
            <td>数学</td>
            <td></td>
            <td></td>
         </tr>
         <tr>
            <td>第三节</td>
            <td>科学</td>
            <td>数学</td>
            <td>语文</td>
            <td>外语</td>
            <td>政治</td>
            <td>活动</td>
            <td></td>
         </tr>
         <tr>
            <td>第四节</td>
            <td>科学</td>
            <td>数学</td>
            <td>语文</td>
            <td>外语</td>
            <td>政治</td>
            <td>活动</td>
            <td></td>
         </tr>
         <tr>
            <td>中午</td>
            <td></td>
            <td></td>
            <td></td>
            <td></td>
            <td></td>
            <td></td>
            <td></td>
         </tr>
         <tr>
            <td>第五节</td>
            <td>音乐</td>
            <td>体育</td>
            <td>艺术</td>
            <td>阅读</td>
            <td>游戏</td>
            <td></td>
            <td></td>
         </tr>
         <tr>
            <td>第六节</td>
            <td>音乐</td>
            <td>体育</td>
            <td>艺术</td>
            <td>阅读</td>
            <td>游戏</td>
            <td></td>
            <td></td>
         </tr>
         <tr>
            <td>第七节</td>
            <td></td>
            <td></td>
            <td></td>
            <td></td>
            <td>班会</td>
            <td></td>
            <td></td>
         </tr>
         <tr>
            <td>第七节</td>
            <td></td>
            <td></td>
            <td></td>
            <td></td>
            <td>班会</td>
            <td></td>
            <td></td>
         </tr>
      </table>
   </body>
</html>

小结

表格在网页中使用可以使用第三方插件或控件。

相关推荐

  1. 编程笔记 html5&css&js 050 CSS表格2-1

    2024-01-22 13:34:04       29 阅读
  2. 编程笔记 html5&css&js 051 CSS表格2-2

    2024-01-22 13:34:04       30 阅读
  3. 编程笔记 html5&css&js 016 HTML表格

    2024-01-22 13:34:04       35 阅读
  4. 编程笔记 html5&css&js 052 CSS伪类

    2024-01-22 13:34:04       36 阅读
  5. 编程笔记 html5&css&js 055 css默认值

    2024-01-22 13:34:04       30 阅读
  6. 编程笔记 html5&css&js 055 CSS颜色表

    2024-01-22 13:34:04       33 阅读
  7. 编程笔记 html5&css&js 054 CSS默认值

    2024-01-22 13:34:04       31 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-22 13:34:04       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-22 13:34:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-22 13:34:04       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-22 13:34:04       20 阅读

热门阅读

  1. Golang爬虫技术

    2024-01-22 13:34:04       36 阅读
  2. 用go语言删除重复文件

    2024-01-22 13:34:04       36 阅读
  3. Vue.js:构建用户界面的渐进式框架

    2024-01-22 13:34:04       28 阅读
  4. 华为网络设备常用命令大全

    2024-01-22 13:34:04       44 阅读
  5. Vue 批量注册全局组件

    2024-01-22 13:34:04       34 阅读
  6. props传值

    2024-01-22 13:34:04       38 阅读
  7. Spring与Spring Boot:区别与Spring Boot的实战示例

    2024-01-22 13:34:04       30 阅读
  8. MySQL的MVCC

    2024-01-22 13:34:04       25 阅读
  9. unity3d在汽车领域的未来发展趋势浅谈

    2024-01-22 13:34:04       28 阅读