aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/html/element/colgroup/index.html
blob: ad68adfeddaabd36d97b23102f9bebf500c8756d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
---
title: <colgroup>
slug: Web/HTML/Element/colgroup
tags:
  - HTML
  - Web
  - 元素
  - 参考
  - 表格
translation_of: Web/HTML/Element/colgroup
---
<div>{{HTMLRef}}</div>

<p>HTML 中的 表格列组(<em>Column Group </em><strong>&lt;colgroup&gt;</strong>)标签用来定义表中的一组列表。</p>

<div>{{EmbedInteractiveExample("pages/tabbed/colgroup.html","tabbed-taller")}}</div>

<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>

<table class="properties">
 <tbody>
  <tr>
   <th scope="row"><a href="/zh-CN/docs/HTML/Content_categories">内容类别</a></th>
   <td>无。</td>
  </tr>
  <tr>
   <th scope="row">允许的内容</th>
   <td>If the {{htmlattrxref("span", "colgroup")}} attribute is present: none, it is an {{Glossary("empty element")}}.<br>
    If the attribute is not present: zero or more {{HTMLElement("col")}} element</td>
  </tr>
  <tr>
   <th scope="row"><span class="op_dict_text2">标签省略</span></th>
   <td>如果元素的第一个子元素存在且是一个 {{HTMLElement("col")}} 元素,而且在它之前没有省略了结束标签的 {{HTMLElement("colgroup")}} 元素,元素的开始标签可以被省略。<br>
    如果之后没有紧跟一个空格或注释,元素的结束标签可以被省略。</td>
  </tr>
  <tr>
   <th scope="row">允许的父元素</th>
   <td>一个 {{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.</td>
  </tr>
  <tr>
   <th scope="row">允许的 ARIA roles</th>
   <td></td>
  </tr>
  <tr>
   <th scope="row">DOM 接口</th>
   <td>{{domxref("HTMLTableColElement")}}</td>
  </tr>
 </tbody>
</table>

<h2 id="属性">属性</h2>

<p>此标签支持 <a href="/zh-CN/docs/Web/HTML/Global_attributes">全局属性</a></p>

<dl>
 <dt>{{htmlattrdef("align")}} {{Deprecated_inline("html4.01")}}, {{obsolete_inline("html5")}}</dt>
 <dd>这个可枚举的属性定义每一列的元素内容的水平对齐方式,支持的值有:</dd>
 <dd>
 <ul>
  <li><code>left</code>,元素中的内容左对齐</li>
  <li><code>center</code>,元素中的内容居中对齐</li>
  <li><code>right</code>,元素中的内容右对齐</li>
  <li><code>justify</code>,插入空格,使元素中内容两端对齐</li>
  <li><code>char</code>,针对确定的字符,设置一个最小偏移量,来进行布局,通过 {{htmlattrxref("char", "col")}}{{htmlattrxref("charoff", "col")}} 属性进行定义 {{unimplemented_inline(2212)}}</li>
 </ul>

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

 <div class="note"><strong>小贴士:</strong>不要使用这个属性,它在最新的标准中已经不被支持。

 <ul>
  <li>若要实现与 <code>left</code>, <code>center</code>, <code>right</code><code>justify</code> 相同的效果:

   <ul>
    <li>不要为一个 {{HTMLElement("colgroup")}} 元素选择器设置 {{cssxref("text-align")}} 属性.,因为{{HTMLElement("td")}} 元素并不是 {{HTMLElement("colgroup")}} 元素的后代,不继承于它。</li>
    <li>如果表格不使用 {{htmlattrxref("colspan", "td")}} 属性,每列用一个 <code>td:nth-child(an+b)</code> 的 CSS 选择器,a 是表格中列的总数,b 是当前列在表格中的位列次序号。只有在这个选择器之后, {{cssxref("text-align")}} 属性可以使用。</li>
    <li>如果表格使用了 {{htmlattrxref("colspan", "td")}} 属性,可以通过合并足够多的属性选择器来实现同样的效果,比如 <code>[colspan=n],但这不常用。</code></li>
   </ul>
  </li>
  <li>若要实现与 <code>char</code> 相同的效果:在 CSS3 中,你可以使用 {{htmlattrxref("char", "colgroup")}} 作为 {{cssxref("text-align")}} 的属性值。 {{unimplemented_inline}}</li>
 </ul>
 </div>
 </dd>
</dl>

<dl>
 <dt>{{htmlattrdef("bgcolor")}} {{Non-standard_inline}}</dt>
 <dd>这个属性用于定义列组中的每一个列成员的背景颜色。在 <a class="external" href="http://www.w3.org/Graphics/Color/sRGB">sRGB</a> 的定义中,它是一个以 '#' 开头的 6 位 16 进制值,有 16 个预定义的表示颜色的字符串可以使用,如下所示:
 <table>
  <tbody>
   <tr>
    <td style="background-color: black; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>  black = "#000000"</code></td>
    <td style="background-color: green; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code> green = "#008000"</code></td>
   </tr>
   <tr>
    <td style="background-color: silver; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code> silver = "#C0C0C0"</code></td>
    <td style="background-color: lime; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>  lime = "#00FF00"</code></td>
   </tr>
   <tr>
    <td style="background-color: gray; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>   gray = "#808080"</code></td>
    <td style="background-color: olive; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code> olive = "#808000"</code></td>
   </tr>
   <tr>
    <td style="background-color: white; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>  white = "#FFFFFF"</code></td>
    <td style="background-color: yellow; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>yellow = "#FFFF00"</code></td>
   </tr>
   <tr>
    <td style="background-color: maroon; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code> maroon = "#800000"</code></td>
    <td style="background-color: navy; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>  navy = "#000080"</code></td>
   </tr>
   <tr>
    <td style="background-color: red; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>    red = "#FF0000"</code></td>
    <td style="background-color: blue; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>  blue = "#0000FF"</code></td>
   </tr>
   <tr>
    <td style="background-color: purple; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code> purple = "#800080"</code></td>
    <td style="background-color: teal; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>  teal = "#008080"</code></td>
   </tr>
   <tr>
    <td style="background-color: fuchsia; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>fuchsia = "#FF00FF"</code></td>
    <td style="background-color: aqua; width: 24px; height: 24px; border-width: 1px; border-color: black; border-style: solid;"></td>
    <td><code>  aqua = "#00FFFF"</code></td>
   </tr>
  </tbody>
 </table>

 <div class="note"><strong>小贴士:</strong><strong> </strong>不要使用这个并未标准化的属性,它只在 IE 的某些版本中生效,{{HTMLElement("colgroup")}} 标签应该使用 CSS 来定义样式。要实现和 <strong>bgcolor</strong> 属性相似的效果,可以在相关的 {{HTMLElement("td")}} 标签上使用 {{cssxref("background-color")}} 属性。</div>
 </dd>
</dl>

<dl>
 <dt>{{htmlattrdef("char")}} {{Deprecated_inline("html4.01")}}, {{obsolete_inline("html5")}}</dt>
 <dd>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 <code>char</code>, 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.
 <div class="note"><strong>Note: </strong>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}}.</div>
 </dd>
</dl>

<dl>
 <dt>{{htmlattrdef("charoff")}} {{Deprecated_inline("html4.01")}}, {{obsolete_inline("html5")}}</dt>
 <dd>This attribute is used to indicate the number of characters to offset the column data from the alignment character specified by the <strong>char</strong> attribute.
 <div class="note"><strong>Note: </strong>Do not use this attribute as it is obsolete (and not supported) in the latest standard.</div>
 </dd>
</dl>

<dl>
 <dt>{{htmlattrdef("span")}}</dt>
 <dd>This attribute contains a positive integer indicating the number of consecutive columns the <code>&lt;colgroup&gt;</code> element spans. If not present, its default value is <code>1</code>.
 <div class="note"><strong>Note: </strong>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.
 <ul>
  <li>The <code>span</code> attribute is not permitted if there are one or more <code>&lt;col&gt;</code> elements within the <code>&lt;colgroup&gt;</code>.</li>
 </ul>
 </div>
 </dd>
</dl>

<dl>
 <dt>{{htmlattrdef("valign")}} {{Deprecated_inline("html4.01")}}, {{obsolete_inline("html5")}}</dt>
 <dd>This attribute specifies the vertical alignment of the text within each cell of the column. Possible values for this attribute are:
 <ul>
  <li><code>baseline</code>, which will put the text as close to the bottom of the cell as it is possible, but align it on the <a class="external" href="https://en.wikipedia.org/wiki/Baseline_%28typography%29">baseline</a> of the characters instead of the bottom of them. If characters are all of the size, this has the same effect as <code>bottom</code>.</li>
  <li><code>bottom</code>, which will put the text as close to the bottom of the cell as it is possible;</li>
  <li><code>middle</code>, which will center the text in the cell;</li>
  <li>and <code>top</code>, which will put the text as close to the top of the cell as it is possible.</li>
 </ul>

 <div class="note"><strong>Note: </strong>Do not use this attribute as it is obsolete (and not supported) in the latest standard:

 <ul>
  <li>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.</li>
  <li>If the table doesn't use a {{htmlattrxref("colspan", "td")}} attribute, use the <code>td:nth-child(an+b)</code> 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.</li>
  <li>If the table does use a {{htmlattrxref("colspan", "td")}} attribute, the effect can be achieved by combining adequate CSS attribute selectors like <code>[colspan=n]</code>, though this is not trivial.</li>
 </ul>
 </div>
 </dd>
</dl>

<dl>
 <dt>{{htmlattrdef("width")}} {{obsolete_inline("html5")}}</dt>
 <dd>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 <code>0*</code>, 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 <code>0.5*</code> also can be used.</dd>
</dl>

<h2 id="示例">示例</h2>

<p>请参考 {{HTMLElement("table")}} 页面以查看 <code>&lt;colgroup&gt;</code> 的示例。</p>

<h2 id="规范">规范</h2>

<table class="standard-table">
 <thead>
  <tr>
   <th scope="col">规范</th>
   <th scope="col">状态</th>
   <th scope="col">备注</th>
  </tr>
 </thead>
 <tbody>
  <tr>
   <td>{{SpecName('HTML WHATWG', 'tabular-data.html#the-colgroup-element', '&lt;colgroup&gt;')}}</td>
   <td>{{Spec2('HTML WHATWG')}}</td>
   <td></td>
  </tr>
  <tr>
   <td>{{SpecName('HTML5 W3C', 'tabular-data.html#the-colgroup-element', '&lt;colgroup&gt;')}}</td>
   <td>{{Spec2('HTML5 W3C')}}</td>
   <td></td>
  </tr>
  <tr>
   <td>{{SpecName('HTML4.01', 'tables.html#edef-COLGROUP', '&lt;colgroup&gt;')}}</td>
   <td>{{Spec2('HTML4.01')}}</td>
   <td></td>
  </tr>
 </tbody>
</table>

<h2 id="浏览器兼容性">浏览器兼容性</h2>



<p>{{Compat("html.elements.colgroup")}}</p>

<h2 id="参见">参见</h2>

<ul>
 <li>其他与表格有关的 HTML 元素:{{HTMLElement("caption")}}{{HTMLElement("col")}}{{HTMLElement("table")}}{{HTMLElement("tbody")}}{{HTMLElement("td")}}{{HTMLElement("tfoot")}}{{HTMLElement("th")}}{{HTMLElement("thead")}}{{HTMLElement("tr")}}</li>
 <li><code>&lt;col&gt;</code> 元素编写样式时特别有用的 CSS 属性和伪类:
  <ul>
   <li>{{cssxref("width")}} 属性可用于控制列宽;</li>
   <li>{{cssxref(":nth-child")}} 伪类可用于针对特定单元格设置对齐方式;</li>
   <li>{{cssxref("text-align")}} 属性可用于按照某一个字符对齐所有单元格的内容,例如 '.'。</li>
  </ul>
 </li>
</ul>