1. 給開發者的 Web 技術文件
  2. HTML:超文本標記語言
  3. HTML 參考
  4. Elements
  5. <table>

此頁面由社群從英文翻譯而來。了解更多並加入 MDN Web Docs 社群。

View in English Always switch to English

<table>(表格元素)

Baseline Widely available *

This feature is well established and works across many devices and browser versions. It’s been available across browsers since ⁨2015年7月⁩.

* Some parts of this feature may have varying levels of support.

HTML <table> 元件代表表格數據 ── 換句話說,就是透過二維資料表來呈現資訊。

嘗試一下

<table>
 <caption>
 2021 前端 Web 開發課程
 </caption>
 <thead>
 <tr>
 <th scope="col">學生</th>
 <th scope="col">對什麼感興趣</th>
 <th scope="col">年齡</th>
 </tr>
 </thead>
 <tbody>
 <tr>
 <th scope="row">Chris</th>
 <td>HTML 表格</td>
 <td>22</td>
 </tr>
 <tr>
 <th scope="row">Dennis</th>
 <td>Web 無障礙</td>
 <td>45</td>
 </tr>
 <tr>
 <th scope="row">Sarah</th>
 <td>JavaScript 框架</td>
 <td>29</td>
 </tr>
 <tr>
 <th scope="row">Karen</th>
 <td>Web 效能</td>
 <td>36</td>
 </tr>
 </tbody>
 <tfoot>
 <tr>
 <th scope="row" colspan="2">平均年齡</th>
 <td>33</td>
 </tr>
 </tfoot>
</table>
table {
 border-collapse: collapse;
 border: 2px solid rgb(140 140 140);
 font-family: sans-serif;
 font-size: 0.8rem;
 letter-spacing: 1px;
}
caption {
 caption-side: bottom;
 padding: 10px;
 font-weight: bold;
}
thead,
tfoot {
 background-color: rgb(228 240 245);
}
th,
td {
 border: 1px solid rgb(160 160 160);
 padding: 8px 10px;
}
td:last-of-type {
 text-align: center;
}
tbody > tr:nth-of-type(even) {
 background-color: rgb(237 238 242);
}
tfoot th {
 text-align: right;
}
tfoot td {
 font-weight: bold;
}
內容類型 流內容
允許內容
按照以下順序:
  1. 一個可選的<caption>元素,
  2. 零個或更多的<colgroup>元素,
  3. 一個可選的<thead>元素,
  4. 一個在以下元素之前或之後的可選 <tfoot> 元素:
    • 零個或更多的<tbody>元素,
    • 或者,一個或更多的<tr>元素
標籤省略 不允許,開始和結束標籤都是必須的。
允許父元素 任何允許流內容的元素
允許 ARIA 規則 任何
DOM 介面 HTMLTableElement

屬性

這個元件包含了 全域屬性(global attributes)

棄用屬性

align 已棄用

這個枚舉屬性會指示表格中的文字要如何對齊。可用值如下:left:意思是表格應該顯示在文件的左方。

  • center:意思是表格應該顯示在文件的中間。
  • right:意思是表格應該顯示在文件的右方。在 CSS 要得出類似效果,應該設定 margin-leftmargin-right;如果要置中,則要把 margin 屬性設定為 0 auto
bgcolor 已棄用

定義表格的背景與內容顏色。它使用六位十六進制 RGB code,前缀需要加上 '#' 。也可以用預先定義的顏色字串可用。在 CSS 要得出類似效果,應該使用 background-color 屬性。

border 已棄用

這個屬性以像素為單位,定義了圍繞於表格框架的大小。如果設為 0,代表 frame 屬性為空。在 CSS 要得出類似效果,應該使用 border 屬性。

cellpadding 已棄用

這個屬性定義了元件與邊界線之間的空白,以及要不要顯示。如果輸入像素,像素長度的空白會套用到四個邊;如果輸入百分比,內容將居中、整體的垂直空間(上與下)會使用這個百分比表示。橫向空間(左與右)也適用這個規則。在 CSS 要得出類似效果,應該對 <table> 屬性使用 border-collapse;並對 <td> 使用 padding

cellspacing 已棄用

This attribute defines the size of the space between two cells in a percentage value or pixels. The attribute is applied both horizontally and vertically, to the space between the top of the table and the cells of the first row, the left of the table and the first column, the right of the table and the last column and the bottom of the table and the last row.To achieve a similar effect, apply the border-spacing property to the <table> element. border-spacing does not have any effect if border-collapse is set to collapse.

frame 已棄用

這個枚舉屬性定義圍繞在表格邊框的哪一邊要顯示。在 CSS 要得出類似效果,應該使用 border-styleborder-width 屬性。

rules 已棄用

這個枚舉屬性定義諸如線條之類的規則,要如何出現在表格。它擁有以下數值:none,代表沒有任何規則上的指示。這是預設值。

  • groups,只標示行群組和列群組(行群組由 <thead><tbody>、和 <tfoot> 定義;列群組由 <col><colgroup> 定義);
  • rows,會創立一組標示行的規則;
  • columns,會創立一組標示列的規則;
  • all,會創立一組同時標示行與列的規則。在 CSS 要得出類似效果,應該針對 <thead><tbody><tfoot><col><colgroup> 元素使用 border 屬性。
summary 已棄用

這個屬性定義了總結表格的替代文字。請改用 <caption> 元素。

width 已棄用

這個屬性定義了表格的寬度。請改用 CSS width 屬性。

範例

簡單的表格

html
<table>
 <tr>
 <td>John</td>
 <td>Doe</td>
 </tr>
 <tr>
 <td>Jane</td>
 <td>Doe</td>
 </tr>
</table>

更多範例

html
<p>有表頭的簡單表格</p>
<table>
 <tr>
 <th>姓</th>
 <th>名</th>
 </tr>
 <tr>
 <td>Doe</td>
 <td>John</td>
 </tr>
 <tr>
 <td>Doe</td>
 <td>Jane</td>
 </tr>
</table>
<p>有 thead、tfoot 和 tbody 的表格</p>
<table>
 <thead>
 <tr>
 <th>表頭 1</th>
 <th>表頭 2</th>
 </tr>
 </thead>
 <tfoot>
 <tr>
 <td>頁腳 1</td>
 <td>頁腳 2</td>
 </tr>
 </tfoot>
 <tbody>
 <tr>
 <td>主體內容 1</td>
 <td>主體內容 2</td>
 </tr>
 </tbody>
</table>
<p>有 colgroup 的表格</p>
<table>
 <colgroup span="4"></colgroup>
 <tr>
 <th>國家</th>
 <th>首都</th>
 <th>人口</th>
 <th>語言</th>
 </tr>
 <tr>
 <td>美國</td>
 <td>華盛頓</td>
 <td>三億零九百萬</td>
 <td>英文</td>
 </tr>
 <tr>
 <td>瑞典</td>
 <td>斯德哥爾摩</td>
 <td>九百萬</td>
 <td>瑞典文</td>
 </tr>
</table>
<p>有colgroup和col的表格</p>
<table>
 <colgroup>
 <col style="background-color: #0f0" />
 <col span="2" />
 </colgroup>
 <tr>
 <th>酸橙</th>
 <th>檸檬</th>
 <th>橘子</th>
 </tr>
 <tr>
 <td>綠</td>
 <td>黃</td>
 <td>橙</td>
 </tr>
</table>
<p>有標題的簡單表格</p>
<table>
 <caption>
 美妙的標題
 </caption>
 <tr>
 <td>美妙的內容</td>
 </tr>
</table>
table {
 border-collapse: collapse;
 border-spacing: 0px;
}
table,
th,
td {
 padding: 5px;
 border: 1px solid black;
}

無障礙議題

Caption

提供 <caption> 元素,以便清晰而簡潔地描述表格主旨。他能讓用戶決定自己是否該閱讀表格內容,還是要略過就好。

如此也能幫助螢幕閱讀器之類的輔具使用者、視力條件差、還有認知障礙的人。

Scope 行列

雖然在 HTML5 裡面 scope 屬性已經過時,但很多螢幕閱讀器會利用這屬性,複製不使用屏幕閱讀器的人的視覺關聯,以便推斷可能的視覺位置。

示例

html
<table>
 <caption>
 Color names and values
 </caption>
 <tbody>
 <tr>
 <th scope="col">名稱</th>
 <th scope="col">HEX</th>
 <th scope="col">HSLa</th>
 <th scope="col">RGBa</th>
 </tr>
 <tr>
 <th scope="row">青色</th>
 <td><code>#51F6F6</code></td>
 <td><code>hsla(180, 90%, 64%, 1)</code></td>
 <td><code>rgba(81, 246, 246, 1)</code></td>
 </tr>
 <tr>
 <th scope="row">金針菇色</th>
 <td><code>#F6BC57</code></td>
 <td><code>hsla(38, 90%, 65%, 1)</code></td>
 <td><code>rgba(246, 188, 87, 1)</code></td>
 </tr>
 </tbody>
</table>

<th> 元素提供 scope="col" 的宣告,有助於描述該單位屬於第一列。在 <td> 元素提供 scope="row" 則有助於描述該單位屬於第一行。

複雜的表格

針對單格複雜到無法歸類於直向或橫向的表格,諸如螢幕閱讀器之類的輔助技術,可能就無法解析。在這種情況下,通常就需要 colspanrowspan 屬性。

理想情況下,可以考慮使用其他方式來呈現表格的內容,例如把表格切分到不必依賴 colspanrowspan 屬性。除了幫助使用輔助技術的人了解表格的內容之外,這樣也會使認知障礙者受益,因為他們可能難以理解表格佈局描述的關聯。

如果表格無法切分,請結合 [id](/zh-TW/docs/Web/HTML/Global_attributes#id) 與 [headers](/zh-TW/docs/Web/HTML/Element/td#headers) 使用,以便程序化地關聯各表格單位與標題。

規範

Specification
HTML
# the-table-element

瀏覽器相容性

參見

Help improve MDN

Learn how to contribute

This page was last modified on by MDN contributors.

AltStyle によって変換されたページ (->オリジナル) /