Syntax | <table>...</table> |
---|---|
Attribute Specifications |
|
Contents | An optional caption, followed by zero or more col and colgroup elements, followed by an optional thead element, an optional tfoot element, and then one or more tbody elements |
Contained in | applet, blockquote, body, button, center, dd, del, div, fieldset, form, iframe, ins, li, map, noframes, noscript, object, td, th |
The table element defines a table for multi-dimensional data arranged in rows and columns. table is commonly used as a layout device, but authors should avoid this practice as much as possible. Tables can cause problems for users of narrow windows, large fonts, or non-visual browsers, and these problems are often accentuated when tables are used solely for layout purposes. As well, current visual browsers will not display anything until the complete table has been downloaded, which can have very noticeable effects when an entire document is laid out within a table. Authors should try to use style sheets in place of table for layout, though bugs in current browser implementations of style sheets can make this difficult.
The table may contain a number of optional elements to provide a rich structure to the table. The optional caption element gives a caption for the table and is followed by optional col and colgroup elements that specify column widths and groupings. The thead, tfoot, and tbody elements then follow with groups of rows. The optional thead and tfoot elements contain header and footer rows, respectively, while tbody elements supply the table's main row groups. A row group contains tr elements for individual rows, and each tr contains th or td elements for header cells or data cells, respectively.
At least one tbody element is required within a table, but tbody's start and end tags are both optional if there is only one tbody and no thead or tfoot. A simple table could thus be expressed as follows:
<table>
<tr>
<th>Abbreviation</th>
<th>Long Form</th>
</tr>
<tr>
<td>AFAIK</td>
<td>As Far As I Know</td>
</tr>
<tr>
<td>IMHO</td>
<td>In My Humble Opinion</td>
</tr>
<tr>
<td>OTOH</td>
<td>On The Other Hand</td>
</tr>
</table>
The same table could be expressed with a richer structure by grouping rows and adding a caption, as in the next example. The extra structural information allows an author to more easily suggest the presentation of the table using style sheets or table's presentational attributes.
<table>
<caption>Common Usenet Abbreviations</caption>
<thead>
<tr>
<th>Abbreviation</th>
<th>Long Form</th>
</tr>
</thead>
<tbody>
<tr>
<td>AFAIK</td>
<td>As Far As I Know</td>
</tr>
<tr>
<td>IMHO</td>
<td>In My Humble Opinion</td>
</tr>
<tr>
<td>OTOH</td>
<td>On The Other Hand</td>
</tr>
</tbody>
</table>
The table element takes an optional summary attribute to describe the purpose and/or structure of the table. The overview provided by the summary attribute is particularly helpful to users of non-visual browsers. With simple tables, a good caption is usually a sufficient summary, but complex tables may benefit from a more detailed overview via the summary attribute. The following example uses summary to describe a table. Note that the summary could also be included in a paragraph before the table, which is helpful since few browsers support summary.
<table summary="This table gives the character entity reference,
decimal character reference, and hexadecimal character
reference for symbols and Greek letters.">
<colgroup>
<colgroup span="3">
<thead>
<tr>
<th scope="col">Character</th>
<th scope="col">Entity</th>
<th scope="col">Decimal</th>
<th scope="col">Hex</th>
</tr>
</thead>
<tbody>
<tr>
<td scope="row">Latin small f with hook</td>
<td>&fnof;</td>
<td>&#402;</td>
<td>&#x192;</td>
</tr>
...
</tbody>
</table>
The table element also takes a number of optional attributes to provide presentational hints in visual browsers. Equivalents of these attributes in Cascading Style Sheets are under development and not widely supported by browsers.
The width attribute specifies the width of the table as a number of pixels or as a percentage of the available horizontal space. Widths in pixels should be avoided, especially widths above 500 pixels, since this causes unnecessary horizontal scrolling for some users.
The border attribute specifies the width in pixels of the border around a table.
The frame attribute, poorly supported by browsers, specifies which sides of the table's outer border are visible. Possible values are void for no border, above for a top border only, below for a bottom border only, hsides for left and right borders only, vsides for top and bottom borders only, lhs for a left border only, rhs for a right border only, and either box or border for a border on all sides. The default value is void unless the border attribute gives a positive width, in which case frame="border" is the default. <table border="border"> is a valid, well-supported shorthand for <table frame="border">.
The rules attribute, poorly supported by browsers, specifies the borders between table cells. Possible values are none for no inner borders, groups for borders between row groups and column groups only, rows for borders between rows only, cols for borders between columns only, and all for borders between all cells. none is the default value if border="0" is used or if no border attribute is given. all is the default value for any other use of border.
The cellspacing attribute defines the amount of space between table cells, and the cellpadding attribute defines the amount of space within table cells (i.e., between the border and cell contents). The value may be given as a number of pixels or as a percentage, though most browsers do not support percentages, treating cellpadding="20%" as if it were cellpadding="20". A percentage value is relative to the vertical space available for vertical padding or spacing, and the amount is split evenly between the top and bottom. Horizontal padding and spacing behave similarly. The padding or spacing is always applied to all four sides.
The padding properties of Cascading Style Sheets allow an author to suggest different padding for different sides, but are not as well supported as the cellpadding attribute.
The deprecated align attribute suggests the horizontal alignment of the table on visual browsers. Possible values are left, right, and center. Browsers generally present left- or right-aligned tables as floating tables, with the content following the table flowing around it. To prevent content from flowing around the table, use <br clear="all"> after the end of the table or the CSS clear property on the next element.
Since many browsers do not support align="center" with table, authors may wish to place the table within a center element.
Style sheets provide more flexibility in suggesting table alignment but with less browser support than the align attribute.
The deprecated bgcolor attribute suggests a background color for the table. The combination of this attribute with <font color="..."> can leave invisible or unreadable text on Netscape Navigator 2.x, which does not support bgcolor on table elements. bgcolor is dangerous even on supporting browsers, since most fail to override it when overriding other author-specified colors. Style sheets provide a safer, more flexible method of specifying a table's background color.