<td>: The Table Data Cell element

<td> HTML 元素定义包含数据的表的单元格,并且可以用作 <tr> 元素的子元素。

¥The <td> HTML element defines a cell of a table that contains data and may be used as a child of the <tr> element.

Try it

属性

¥Attributes

该元素包括 全局属性

¥This element includes the global attributes.

colspan

包含一个非负整数值,指示数据单元格跨越或延伸的列数。默认值为 1。用户代理将高于 1000 的值视为不正确而忽略,设置为默认值 (1)。

headers

包含以空格分隔的字符串列表,每个字符串对应于为此表单元格提供标题的 <th> 元素的 id 属性。

rowspan

包含一个非负整数值,指示数据单元格跨越或延伸的行数。默认值为 1;如果其值设置为 0,则它会延伸到单元格所属的表分组部分的末尾(<thead><tbody><tfoot>,即使是隐式定义的)。高于 65534 的值将被剪裁为 65534

已弃用的属性

¥Deprecated attributes

以下属性已被弃用,不应使用。下面记录了它们,供更新现有代码时参考,并且仅供历史参考。

¥The following attributes are deprecated and should not be used. They are documented below for reference when updating existing code and for historical interest only.

abbr Deprecated

包含数据单元内容的简短描述。某些用户代理(例如语音阅读器)可能会在内容本身之前呈现此描述。将缩写内容放入单元格内,并将(较长)描述放入 title 属性中,因为该属性已弃用。或者,最好将内容包含在数据单元格内,并使用 CSS 至 视觉上剪辑溢出的文本

align Deprecated

指定数据单元格的水平对齐方式。可能的 enumerated 值为 leftcenterrightjustifychar。如果支持,char 值会将文本内容与 char 属性中定义的字符和 charoff 属性定义的偏移量对齐。请改用 text-align CSS 属性,因为此属性已弃用。

axis Deprecated

包含以空格分隔的字符串列表,每个字符串对应于数据单元格应用到的一组单元格的 id 属性。

bgcolor Deprecated

定义数据单元格的背景颜色。该值是 HTML 颜色;6 位十六进制 RGB 代码(前缀为“#”)或 颜色关键词。不支持其他 CSS <color> 值。请改用 background-color CSS 属性,因为此属性已弃用。

char Deprecated

不执行任何操作。它最初旨在指定内容与数据单元格的字符的对齐方式。当尝试对齐数字或货币值时,此值的典型值包括句点 (.)。如果 align 未设置为 char,则忽略该属性。

charoff Deprecated

不执行任何操作。原本是想指定数据单元格内容与 char 属性指定的对齐字符之间的偏移字符数。

height Deprecated

定义建议的数据单元高度。请改用 height CSS 属性,因为此属性已弃用。

scope Deprecated

定义与标题(在 <th> 中定义)元素相关的单元格。可能的 enumerated 值为 rowcolrowgroupcolgroup。仅将此属性与 <th> 元素一起使用来定义它作为标题的行或列,因为 <td> 元素不推荐使用此属性。

valign Deprecated

指定数据单元格的垂直对齐方式。可能的 enumerated 值为 baselinebottommiddletop。请改用 vertical-align CSS 属性,因为此属性已弃用。

width Deprecated

定义推荐的数据单元宽度。请改用 width CSS 属性,因为此属性已弃用。

使用说明

¥Usage notes

  • <td> 只能在 <tr> 元素内使用。
  • 当使用 colspanrowspan 属性跨越多个列和行的数据单元格时,未定义这些属性的单元格(默认值为 1)将自动适应表结构中跨越 1x1 单元格的可用空间,如 下图:

Illustration demonstrating column and row spanning of table cells: cells 1, 3, and 4 spanning two rows; cell 2 spanning two columns; cells 5 and 6 fitting into the available cells that are the second and third columns in the second row

注意:这些属性不得用于重叠单元格。

¥Note: These attributes must not be used to overlap cells.

示例

¥Examples

请参阅 <table> 了解介绍通用标准和最佳实践的完整表格示例。

¥See <table> for a complete table example introducing common standards and best practices.

基本数据单元格

¥Basic data cells

此示例使用 <td> 元素以及其他与表相关的元素来引入包含有关拼音字母表的数据的基本表。

¥This example uses <td> elements along with other table-related elements to introduce a basic table with data about the phonetic alphabet.

HTML

某些表行(<tr> 元素)包含标题单元格(<th> 元素)和数据单元格 <td> 元素。作为每行的第一个子元素的 <th> 元素形成表的第一列,每个 <th> 提供该行中数据单元格的行标题。每个相应的 <td> 元素包含与其各自的列标题和行标题单元格对齐的数据。

¥Some table rows (<tr> elements) contain both header cells (<th> elements) and data cell <td> elements. The <th> element that is the first child of each row forms the first column of the table, with each <th> providing the row header for the data cells within that row. Each corresponding <td> element contains data aligned with its respective column header and row header cell.

注意:通常,会实现带有列标题的表头组,以便更容易理解列中的信息。<thead><tbody> 元素将用于将此类标题和数据行分组到相应的表头和正文部分。在此示例中未实现这一点,以专注于数据单元并降低该示例的复杂性。

¥Note: Normally, a table head group with column headers would be implemented to make it easier to understand the information in the columns. The <thead> and <tbody> elements would be used to group such rows of headers and data into the respective table head and body sections. This is not implemented in this example to focus on the data cells and reduce the complexity of this example.

html

<table>
  <tr>
    <th scope="row">A</th>
    <td>阿尔法</td> 
    <td>阿尔法赫</td>
  </tr>
  <tr>
    <th scope="row">B</th>
    <td>布拉沃</td> 
    <td>BRAH voh</td>
  </tr> 
  <tr>
    <th scope="row">C</th>
    <td>查理</td> 
    <td>查利</td>
  </tr>
  <tr>
    <th scope="row">D</th>
    <td>三角洲</td> 
    <td>戴尔他</td>
  </tr>
</table>


CSS

一些基本的 CSS 用于设置表格及其单元格的样式。CSS 属性选择器:nth-of-type 伪类用于交替单元格的外观,以使表中的信息更易于理解和识别。

¥Some basic CSS is used to style the table and its cells. CSS attribute selectors and the :nth-of-type pseudo-class are used to alternate the appearance of the cells to make the information in the table easier to understand and identify.

css
td,
th {
  border: 1px solid rgb(160 160 160);
  padding: 8px 10px;
}

tr:nth-of-type(odd) td {
  background-color: #eee;
}

tr th[scope="row"] {
  background-color: #d6ecd4;
}
css
table {
  border-collapse: collapse;
  border: 2px solid rgb(140 140 140);
  font-family: sans-serif;
  font-size: 0.8rem;
  letter-spacing: 1px;
}

结果

¥Result

列和行跨越

¥Column and row spanning

此示例通过添加额外的 "ABC" 单元格来扩展和增强 前面的例子 的基本表。

¥This example extends and enhances the basic table from the previous example by adding an additional "ABC" cell.

HTML

在第一行(<tr> 元素)内引入了附加数据单元(<td> 元素)。这将在表中创建第四列。

¥An additional data cell (<td> element) is introduced within the first row (<tr> element). This creates a fourth column in the table.

使用 rowspan 属性,"ABC" 单元格跨越表的前三行。后续行的最后一个数据单元格各跨两列。这是使用 colspan 属性完成的,在表结构中正确对齐它们。请注意,表中添加了附加行(<tr> 元素)来说明这一点。

¥Using the rowspan attribute, the "ABC" cell is spanned across the first three rows of the table. The last data cells of the subsequent rows each span two columns. This is done using the colspan attribute, aligning them correctly within the table structure. Note that an additional row (<tr> element) is added to the table to illustrate this.

html

<table>
  <tr>
    <th scope="row">A</th>
    <td>阿尔法</td> 
    <td>阿尔法赫</td>
    <td rowspan="3">ABC</td>
  </tr>
  <tr>
    <th scope="row">B</th>
    <td>布拉沃</td> 
    <td>BRAH voh</td>
  </tr> 
  <tr>
    <th scope="row">C</th>
    <td>查理</td> 
    <td>查利</td>
  </tr>
  <tr>
    <th scope="row">D</th>
    <td>三角洲</td> 
    <td colspan="2">戴尔他</td>
  </tr> 
  <tr>
    <th scope="row">E</th>
    <td>回声</td> 
    <td colspan="2">心电图哦</td>
  </tr>
</table>


CSS

CSS 中使用 :first-of-type:last-of-type 伪类来选择添加的 "ABC" 数据单元并设置其样式。

¥The :first-of-type and :last-of-type pseudo-classes are used in the CSS to select and style the added "ABC" data cell.

css
tr:first-of-type td:last-of-type {
  width: 60px;
  background-color: #505050;
  color: #fff;
  font-weight: bold;
  text-align: center;
}

td,
th {
  border: 1px solid rgb(160 160 160);
  padding: 8px 10px;
}

tr:nth-of-type(odd) td {
  background-color: #eee;
}

tr th[scope="row"] {
  background-color: #d6ecd4;
}
css
table {
  border-collapse: collapse;
  border: 2px solid rgb(140 140 140);
  font-family: sans-serif;
  font-size: 0.8rem;
  letter-spacing: 1px;
}

结果

¥Result

将数据单元格与标题单元格关联

¥Associate data cells with header cells

对于数据单元格(<td> 元素)和标题单元格(<th> 元素)之间更复杂的关系,单独使用 <th> 元素和 scope 属性可能不足以满足辅助技术的需要,尤其是屏幕阅读器。

¥For more complex relationships between data cells (<td> elements) and header cells (<th> elements), using <th> elements with the scope attribute alone may not be sufficient for assistive technologies, especially screen readers.

HTML

例如,为了改进 前面的例子accessibility 并允许屏幕阅读器说出与每个数据单元格关联的标题,可以将 headers 属性与 id 属性一起引入。与 "ABC" 数据单元(即字母 "A"、"B" 和 "C")关联的每个行标题单元(<th> 元素)都被赋予一个具有 id 属性的唯一标识符。然后,"ABC" 数据单元(<td> 元素)使用空格分隔列表中的这些 id 值作为 headers 属性。

¥To improve the accessibility of the previous example and to allow screen readers, for example, to speak the headers associated with each data cell, the headers attribute can be introduced along with id attributes. Each row header cell (<th> element) associated with the "ABC" data cell, i.e., the letters "A", "B", and "C", is given a unique identifier with the id attribute. The "ABC" data cell (<td> element) then uses these id values in a space-separated list for the headers attribute.

注意:建议对 id 属性使用更具描述性和有用的值。文档中的每个 id 对于该文档来说必须是唯一的。在此示例中,id 值是单个字符,以保持对 headers 属性概念的关注。

¥Note: It's recommended to use more descriptive and useful values for the id attribute. Each id in a document must be unique to that document. In this example, the id values are single characters to maintain focus on the concept of the headers attribute.

html

<table>
  <tr>
    <th id="a" scope="row">A</th>
    <td>阿尔法</td> 
    <td>阿尔法赫</td>
    <td headers="a b c" rowspan="3">ABC</td>
  </tr>
  <tr>
    <th id="b" scope="row">B</th>
    <td>布拉沃</td> 
    <td>BRAH voh</td>
  </tr> 
  <tr>
    <th id="c" scope="row">C</th>
    <td>查理</td> 
    <td>查利</td>
  </tr>
  <tr>
    <th scope="row">D</th>
    <td>三角洲</td> 
    <td colspan="2">戴尔他</td>
  </tr> 
  <tr>
    <th scope="row">E</th>
    <td>回声</td> 
    <td colspan="2">心电图哦</td>
  </tr>
</table>


结果

¥Result

虽然 视觉结果前面的示例表 相比没有变化,但每个数据单元格 (<td>) 现在都与其行标题单元格 (<th>) 显式关联。

¥While the visual result is unchanged from the previous example table, each data cell (<td>) is now explicitly associated with its row header cell (<th>).

技术总结

¥Technical summary

内容类别 切根。
允许的内容 流量内容.
标签遗漏 开始标记是强制性的。
如果结束标记后面紧跟着 <th><td> 元素或者其父元素中没有更多数据,则可以省略结束标记。
允许的父级 <tr> 元素。
隐式 ARIA 角色 cell 如果是 <table> 元素的后代
允许的 ARIA 角色 任何
DOM 接口 HTMLTableCellElement

规范

Specification
HTML Standard
# the-td-element

¥Specifications

浏览器兼容性

BCD tables only load in the browser

¥Browser compatibility

也可以看看

¥See also