<colgroup>: The Table Column Group element #
::: section-content
The <colgroup>
HTML element defines a group of columns
within a table.
:::
Try it #
::: section-content ::: iframe ::: {.output-header .border-rounded-top}
HTML Demo: <colgroup> #
Reset :::
::: {#warning-no-script .warning-container} ::: warning The interactive example cannot be shown because JavaScript is disabled. ::: :::
::: {#warning-mathml-not-supported .warning-container .hidden} ::: warning The interactive example cannot be shown because MathML is not supported by your browser. ::: :::
::: {#editor-container .editor-container .tabbed-taller .hidden .border-rounded-bottom editor-type=“tabbed”} ::: {#tab-container .section .tabs} ::: {#tablist .tab-list role=“tablist”} HTML
CSS
JavaScript :::
::: {#html-panel .section .hidden tabindex=“0” role=“tabpanel” aria-labelledby=“html” aria-hidden=“true”} ::: {#html-editor}
 | Batman | Robin | The Flash | Kid Flash |
---|---|---|---|---|
Skill | Smarts | Dex, acrobat | Super speed | Super speed |
::: {#css-panel .section .hidden tabindex=“0” role=“tabpanel” aria-labelledby=“css” aria-hidden=“true”} ::: {#css-editor} .batman { background-color: #d7d9f2; }
.flash {
background-color: #ffe8d4;
}
caption {
padding: 8px;
caption-side: bottom;
}
table {
border-collapse: collapse;
border: 2px solid rgb(100, 100, 100);
letter-spacing: 1px;
font-family: sans-serif;
font-size: 0.7rem;
}
td,
th {
border: 1px solid rgb(100, 100, 100);
padding: 10px 10px;
}
td {
text-align: center;
}
::: :::
::: {#js-panel .section .hidden tabindex=“0” role=“tabpanel” aria-labelledby=“js” aria-hidden=“true”} ::: {#js-editor} ::: ::: :::
::: {#output .output-container}
Output #
::: :::
::: {.section .console-container .hidden aria-hidden=“true”}
Console Output #
![] clear console
::: {#console .console} ::: :::
::: {#html-output .output .editor-tabbed} %html-content% ::: ::: :::
Attributes #
::: section-content This element's attributes include the global attributes.
span
This attribute contains a positive integer indicating the number of consecutive columns the
<colgroup>
element spans. If not present, its default value is1
.The
span
attribute is not permitted if there are one or more<col>
elements within the<colgroup>
. :::
Deprecated attributes #
::: section-content 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.
align
[Deprecated]{.visually-hidden}This enumerated attribute specifies how horizontal alignment of each column cell content will be handled. Possible values are:
left
, aligning the content to the left of the cellcenter
, centering the content in the cellright
, aligning the content to the right of the celljustify
, inserting spaces into the textual content so that the content is justified in the cellchar
, aligning the textual content on a special character with a minimal offset, defined by thechar
andcharoff
attributes.
If this attribute is not set, the
left
value is assumed. The descendant<col>
elements may override this value using their ownalign
attribute.::: {#sect1 .notecard .note} Note: Do not try to set the
text-align
property on a selector giving a<colgroup>
{aria-current=“page”} element. Because<td>
elements are not descendant of the<colgroup>
{aria-current=“page”} element, they won't inherit it.If the table doesn't use a
colspan
attribute, use onetd:nth-child(an+b)
CSS selector per column, where 'a' is the total number of the columns in the table and 'b' is the ordinal position of this column in the table. Only after this selector thetext-align
property can be used.If the table does use a
colspan
attribute, the effect can be achieved by combining adequate CSS attribute selectors like[colspan=n]
, though this is not trivial. :::bgcolor
[Deprecated]{.visually-hidden}The background color of the table. It is a 6-digit hexadecimal RGB code, prefixed by a '
#
'. One of the predefined color keywords can also be used.To achieve a similar effect, use the CSS
background-color
property.char
[Deprecated]{.visually-hidden}This attribute specifies the alignment of the content in a column group to a character. Typical values for this include a period (.) when attempting to align numbers or monetary values. If
align
is not set tochar
, this attribute is ignored, though it will still be used as the default value for thealign
of the<col>
which are members of this column group.charoff
[Deprecated]{.visually-hidden}This attribute is used to indicate the number of characters to offset the column data from the alignment character specified by the
char
attribute.valign
[Deprecated]{.visually-hidden}This attribute specifies the vertical alignment of the text within each cell of the column. Possible values for this attribute are:
baseline
, which will put the text as close to the bottom of the cell as it is possible, but align it on the baseline{target="_blank"} of the characters instead of the bottom of them. If characters are all of the size, this has the same effect asbottom
.bottom
, which will put the text as close to the bottom of the cell as it is possible;middle
, which will center the text in the cell;- and
top
, which will put the text as close to the top of the cell as it is possible.
::: {#sect2 .notecard .note} Note: Do not try to set the
vertical-align
property on a selector giving a<colgroup>
element. Because<td>
elements are not descendant of the<colgroup>
element, they won't inherit it.If the table doesn't use a
colspan
attribute, use thetd:nth-child(an+b)
CSS selector per column, where 'a' is the total number of the columns in the table and 'b' is the ordinal position of the column in the table. Only after this selector thevertical-align
property can be used.If the table does use a
colspan
attribute, the effect can be achieved by combining adequate CSS attribute selectors like[colspan=n]
, though this is not trivial. ::: :::
Examples #
::: section-content
Please see the
<table>
page for examples on <colgroup>
.
:::
Technical summary #
::: section-content
Content categories | None. |
---|---|
Permitted content | If the span attribute is present:
none.If the attribute is not present: zero or more <col> element |
Tag omission | The start tag may be omitted, if it has a <col> element as its first child and
if it is not preceded by a <colgroup> whose end tag has
been omitted.The end tag may be omitted, if it is not followed by a space or a comment. |
Permitted parents | A <table> element. The <colgroup>
must appear after any optional <caption> element but before any
<thead> , <th> , <tbody> , <tfoot> and <tr> element. |
Implicit ARIA role | No corresponding role |
Permitted ARIA roles | No role permitted |
DOM interface | HTMLTableColElement |
Specifications #
::: _table #
Specification #
HTML Standard
[#
the-colgroup-element]{.small}
:::
Browser compatibility #
::: _table Desktop Mobile
Chrome Edge Firefox Internet Explorer Opera Safari WebView Android Chrome Android Firefox for Android Opera Android Safari on IOS Samsung Internet
colgroup
1 12 1 Yes 15 ≤4 4.4 18 4 14 ≤3.2 1.0
align
1 12 1 Yes 15 3 4.4 18 4 14 2 1.0
bgcolor
1 12 1 Yes 15 1 4.4 18 4 14 1 1.0
char
1 12 No Yes 15 3 4.4 18 No 14 2 1.0
charoff
1 12 No Yes 15 3 4.4 18 No 14 2 1.0
span
1 12 1 Yes 15 ≤4 4.4 18 4 14 ≤3.2 1.0
valign
1 12 1 Yes 15 3 4.4 18 4 14 2 1.0
width
1 12 1 Yes 15 ≤4 4.4 18 4 14 ≤3.2 1.0
:::
See also #
::: section-content
- CSS properties and
pseudo-classes
that may be specially useful to style the
<col>
element:- the
width
property to control the width of the column; - the
:nth-child
pseudo-class to set the alignment on the cells of the column; - the
text-align
property to align all cells content on the same character, like '.'. :::
- the
::: _attribution
© 2005–2023 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5
or later.
https://developer.mozilla.org/en-US/docs/Web/HTML/Element/colgroup{._attribution-link}
:::