<table>(表格元素)
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
HTML <table>
元件代表表格數據 ── 換句話說,就是透過二維資料表來呈現資訊。
嘗試一下
內容類型 | 流內容 |
---|---|
允許內容 | |
標籤省略 | 不允許,開始和結束標籤都是必須的。 |
允許父元素 | Any element that accepts flow content |
允許 ARIA 規則 | Any |
DOM 介面 | HTMLTableElement |
屬性
這個元件包含了 全域屬性(global attributes)。
棄用屬性
align
已棄用-
這個枚舉屬性會指示表格中的文字要如何對齊。可用值如下:left:意思是表格應該顯示在文件的左方。
- center:意思是表格應該顯示在文件的中間。
- right:意思是表格應該顯示在文件的右方。在 CSS 要得出類似效果,應該設定
margin-left
與margin-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 ifborder-collapse
is set to collapse. frame
已棄用-
這個枚舉屬性定義圍繞在表格邊框的哪一邊要顯示。在 CSS 要得出類似效果,應該使用
border-style
與border-width
屬性。 rules
已棄用-
這個枚舉屬性定義諸如線條之類的規則,要如何出現在表格。它擁有以下數值:
none
,代表沒有任何規則上的指示。這是預設值。 summary
已棄用-
這個屬性定義了總結表格的替代文字。請改用
<caption>
元素。 width
已棄用-
這個屬性定義了表格的寬度。請改用 CSS
width
屬性。
範例
簡單的表格
<table>
<tr>
<td>John</td>
<td>Doe</td>
</tr>
<tr>
<td>Jane</td>
<td>Doe</td>
</tr>
</table>
更多範例
<p>Simple table with header</p>
<table>
<tr>
<th>First name</th>
<th>Last name</th>
</tr>
<tr>
<td>John</td>
<td>Doe</td>
</tr>
<tr>
<td>Jane</td>
<td>Doe</td>
</tr>
</table>
<p>Table with thead, tfoot, and tbody</p>
<table>
<thead>
<tr>
<th>Header content 1</th>
<th>Header content 2</th>
</tr>
</thead>
<tfoot>
<tr>
<td>Footer content 1</td>
<td>Footer content 2</td>
</tr>
</tfoot>
<tbody>
<tr>
<td>Body content 1</td>
<td>Body content 2</td>
</tr>
</tbody>
</table>
<p>Table with colgroup</p>
<table>
<colgroup span="4"></colgroup>
<tr>
<th>Countries</th>
<th>Capitals</th>
<th>Population</th>
<th>Language</th>
</tr>
<tr>
<td>USA</td>
<td>Washington D.C.</td>
<td>309 million</td>
<td>English</td>
</tr>
<tr>
<td>Sweden</td>
<td>Stockholm</td>
<td>9 million</td>
<td>Swedish</td>
</tr>
</table>
<p>Table with colgroup and col</p>
<table>
<colgroup>
<col style="background-color: #0f0" />
<col span="2" />
</colgroup>
<tr>
<th>Lime</th>
<th>Lemon</th>
<th>Orange</th>
</tr>
<tr>
<td>Green</td>
<td>Yellow</td>
<td>Orange</td>
</tr>
</table>
<p>Simple table with caption</p>
<table>
<caption>
Awesome caption
</caption>
<tr>
<td>Awesome data</td>
</tr>
</table>
無障礙議題
Caption
提供 <caption>
元素,以便清晰而簡潔地描述表格主旨。他能讓用戶決定自己是否該閱讀表格內容,還是要略過就好。
如此也能幫助螢幕閱讀器之類的輔具使用者、視力條件差、還有認知障礙的人。
Scope 行列
雖然在 HTML5 裡面 scope
屬性已經過時,但很多螢幕閱讀器會利用這屬性,複製不使用屏幕閱讀器的人的視覺關聯,以便推斷可能的視覺位置。
示例
<table>
<caption>
Color names and values
</caption>
<tbody>
<tr>
<th scope="col">Name</th>
<th scope="col">HEX</th>
<th scope="col">HSLa</th>
<th scope="col">RGBa</th>
</tr>
<tr>
<th scope="row">Teal</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">Goldenrod</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"
則有助於描述該單位屬於第一行。
- MDN Tables for visually impaired users
- Tables with two headers • Tables • W3C WAI Web Accessibility Tutorials
- Tables with irregular headers • Tables • W3C WAI Web Accessibility Tutorials
- H63: Using the scope attribute to associate header cells and data cells in data tables | W3C Techniques for WCAG 2.0
複雜的表格
針對單格複雜到無法歸類於直向或橫向的表格,諸如螢幕閱讀器之類的輔助技術,可能就無法解析。在這種情況下,通常就需要 colspan
與 rowspan
屬性。
理想情況下,可以考慮使用其他方式來呈現表格的內容,例如把表格切分到不必依賴 colspan
和 rowspan
屬性。除了幫助使用輔助技術的人了解表格的內容之外,這樣也會使認知障礙者受益,因為他們可能難以理解表格佈局描述的關聯。
如果表格無法切分,請結合 [
id](/zh-TW/docs/Web/HTML/Global_attributes#id) 與 [
headers](/zh-TW/docs/Web/HTML/Element/td#headers) 使用,以便程序化地關聯各表格單位與標題。
規範
Specification |
---|
HTML # the-table-element |
瀏覽器相容性
BCD tables only load in the browser
參見
-
CSS properties that may be especially useful to style the
<table>
element:width
to control the width of the table;border
,border-style
,border-color
,border-width
,border-collapse
,border-spacing
to control the aspect of cell borders, rules and frame;margin
andpadding
to style the individual cell content;text-align
andvertical-align
to define the alignment of text and cell content.