--- title: slug: Web/HTML/Element/colgroup tags: - HTML - Web - 元素 - 参考 - 表格 translation_of: Web/HTML/Element/colgroup ---
{{HTMLRef}}

HTML 中的 表格列组(Column Group <colgroup>) 标签用来定义表中的一组列表。

{{EmbedInteractiveExample("pages/tabbed/colgroup.html","tabbed-taller")}}
内容类别 无。
允许的内容 If the {{htmlattrxref("span", "colgroup")}} attribute is present: none, it is an {{Glossary("empty element")}}.
If the attribute is not present: zero or more {{HTMLElement("col")}} element
标签省略 如果元素的第一个子元素存在且是一个 {{HTMLElement("col")}} 元素,而且在它之前没有省略了结束标签的 {{HTMLElement("colgroup")}} 元素,元素的开始标签可以被省略。
如果之后没有紧跟一个空格或注释,元素的结束标签可以被省略。
允许的父元素 一个 {{HTMLElement("table")}} 元素。The {{HTMLElement("colgroup")}} must appear after any optional {{HTMLElement("caption")}} element but before any {{HTMLElement("thead")}}, {{HTMLElement("th")}}, {{HTMLElement("tbody")}}, {{HTMLElement("tfoot")}} and {{HTMLElement("tr")}} element.
允许的 ARIA roles
DOM 接口 {{domxref("HTMLTableColElement")}}

属性

此标签支持 全局属性

{{htmlattrdef("align")}} {{Deprecated_inline("html4.01")}}, {{obsolete_inline("html5")}}
这个可枚举的属性定义每一列的元素内容的水平对齐方式,支持的值有:

此属性的默认值为 left。后代 {{HTMLElement("col")}} 元素可以用它们自己的 {{htmlattrxref("align", "col")}} 属性值来重写该属性。

小贴士: 不要使用这个属性,它在最新的标准中已经不被支持。
  • 若要实现与 left, center, rightjustify 相同的效果:
    • 不要为一个 {{HTMLElement("colgroup")}} 元素选择器设置 {{cssxref("text-align")}} 属性.,因为{{HTMLElement("td")}} 元素并不是 {{HTMLElement("colgroup")}} 元素的后代,不继承于它。
    • 如果表格不使用 {{htmlattrxref("colspan", "td")}} 属性,每列用一个 td:nth-child(an+b) 的 CSS 选择器,a 是表格中列的总数,b 是当前列在表格中的位列次序号。只有在这个选择器之后, {{cssxref("text-align")}} 属性可以使用。
    • 如果表格使用了 {{htmlattrxref("colspan", "td")}} 属性,可以通过合并足够多的属性选择器来实现同样的效果,比如 [colspan=n],但这不常用。
  • 若要实现与 char 相同的效果:在 CSS3 中,你可以使用 {{htmlattrxref("char", "colgroup")}} 作为 {{cssxref("text-align")}} 的属性值。 {{unimplemented_inline}}
{{htmlattrdef("bgcolor")}} {{Non-standard_inline}}
这个属性用于定义列组中的每一个列成员的背景颜色。在 sRGB 的定义中,它是一个以 '#' 开头的 6 位 16 进制值,有 16 个预定义的表示颜色的字符串可以使用,如下所示:
  black = "#000000"  green = "#008000"
 silver = "#C0C0C0"   lime = "#00FF00"
   gray = "#808080"  olive = "#808000"
  white = "#FFFFFF" yellow = "#FFFF00"
 maroon = "#800000"   navy = "#000080"
    red = "#FF0000"   blue = "#0000FF"
 purple = "#800080"   teal = "#008080"
fuchsia = "#FF00FF"   aqua = "#00FFFF"
小贴士: 不要使用这个并未标准化的属性,它只在 IE 的某些版本中生效,{{HTMLElement("colgroup")}} 标签应该使用 CSS 来定义样式。要实现和 bgcolor 属性相似的效果,可以在相关的 {{HTMLElement("td")}} 标签上使用 {{cssxref("background-color")}} 属性。
{{htmlattrdef("char")}} {{Deprecated_inline("html4.01")}}, {{obsolete_inline("html5")}}
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 {{htmlattrxref("align", "colgroup")}} is not set to char, this attribute is ignored, though it will still be used as the default value for the {{htmlattrxref("align", "col")}} of the {{HTMLElement("col")}} which are members of this column group.
Note: Do not use this attribute as it is obsolete (and not supported) in the latest standard. To achieve the same effect as the {{htmlattrxref("char", "colgroup")}}, in CSS3, you can use the character set using the {{htmlattrxref("char", "colgroup")}} attribute as the value of the {{cssxref("text-align")}} property {{unimplemented_inline}}.
{{htmlattrdef("charoff")}} {{Deprecated_inline("html4.01")}}, {{obsolete_inline("html5")}}
This attribute is used to indicate the number of characters to offset the column data from the alignment character specified by the char attribute.
Note: Do not use this attribute as it is obsolete (and not supported) in the latest standard.
{{htmlattrdef("span")}}
This attribute contains a positive integer indicating the number of consecutive columns the <colgroup> element spans. If not present, its default value is 1.
Note: This attribute is applied on the attributes of the column group, it has no effect on the CSS styling rules associated with it or, even more, to the cells of the column's members of the group.
  • The span attribute is not permitted if there are one or more <col> elements within the <colgroup>.
{{htmlattrdef("valign")}} {{Deprecated_inline("html4.01")}}, {{obsolete_inline("html5")}}
This attribute specifies the vertical alignment of the text within each cell of the column. Possible values for this attribute are:
Note: Do not use this attribute as it is obsolete (and not supported) in the latest standard:
  • Do not try to set the {{cssxref("vertical-align")}} property on a selector giving a {{HTMLElement("colgroup")}} element. Because {{HTMLElement("td")}} elements are not descendant of the {{HTMLElement("colgroup")}} element, they won't inherit it.
  • If the table doesn't use a {{htmlattrxref("colspan", "td")}} attribute, use the td: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 the {{cssxref("vertical-align")}} property can be used.
  • If the table does use a {{htmlattrxref("colspan", "td")}} attribute, the effect can be achieved by combining adequate CSS attribute selectors like [colspan=n], though this is not trivial.
{{htmlattrdef("width")}} {{obsolete_inline("html5")}}
This attribute specifies a default width for each column in the current column group. In addition to the standard pixel and percentage values, this attribute might take the special form 0*, which means that the width of each column in the group should be the minimum width necessary to hold the column's contents. Relative widths such as 0.5* also can be used.

示例

请参考 {{HTMLElement("table")}} 页面以查看 <colgroup> 的示例。

规范

规范 状态 备注
{{SpecName('HTML WHATWG', 'tabular-data.html#the-colgroup-element', '<colgroup>')}} {{Spec2('HTML WHATWG')}}
{{SpecName('HTML5 W3C', 'tabular-data.html#the-colgroup-element', '<colgroup>')}} {{Spec2('HTML5 W3C')}}
{{SpecName('HTML4.01', 'tables.html#edef-COLGROUP', '<colgroup>')}} {{Spec2('HTML4.01')}}

浏览器兼容性

{{Compat("html.elements.colgroup")}}

参见