--- title:
HTML の <col>
要素は、表内の列を定義して、すべての一般セルに共通の意味を定義するために使用します。この要素は通常、 {{HTMLElement("colgroup")}} 要素内にみられます。
このデモのソースファイルは GitHub リポジトリに格納されています。デモプロジェクトに協力したい場合は、 https://github.com/mdn/interactive-examples をクローンしてプルリクエストを送信してください。
<col>
では CSS を使用して列にスタイルを設定できますが、列に対して効果があるプロパティは限定されています (CSS 2.1 仕様書 をご覧ください)。
コンテンツカテゴリ | なし |
---|---|
許可されている内容 | なし。これは{{Glossary("empty element", "空要素")}}です。 |
タグの省略 | 開始タグは必須ですが、終了タグを置いてはいけません。 |
許可されている親要素 | {{HTMLElement("colgroup")}} のみ。ただし開始タグが必須ではないため暗黙的に定義されることがあります。 {{HTMLElement("colgroup")}} 要素は {{htmlattrxref("span", "colgroup")}} 属性を持っていてはいけません。 |
暗黙の ARIA ロール | 対応するロールなし |
許可されている ARIA ロール | 許可されている role なし |
DOM インターフェイス | {{domxref("HTMLTableColElement")}} |
この要素にはグローバル属性があります。
<col>
要素がまたがる列の数を示します。存在しない場合、既定値は 1
です。以下の属性は非推奨であり、使用すべきではありません。これらの属性は、既存のコードを更新する際の参考として、また歴史的な興味のためだけに、以下に文書化されています。
left
: 内容物をセルの左側に揃えます。center
: 内容物をセル内で中央揃えにします。right
: 内容物をセルの右側に揃えます。justify
: 内容物がセル内で両端揃えになるように、テキストコンテンツに空白を挿入します。この属性が設定されていない場合、その値は <col>
要素が属する {{HTMLElement("colgroup")}} 要素の {{htmlattrxref("align", "colgroup")}} 属性から継承します。それも存在しない場合は、left
値であるものとします。
left
、center
、right
、justify
と同じ効果を得る方法:
<col>
要素を与えたセレクターに設定しようとしてはいけません。 {{HTMLElement("td")}} 要素は <col>
要素の子孫ではないため、プロパティを継承しません。td:nth-child(an+b)
CSS セレクターを使用してください。 a
を 0 に、b
を表内の列の位置を示す序数にします。例えば td:nth-child(2) { text-align: right; }
は、2 列目を右揃えにします。[colspan=n]
のような、十分な CSS 属性セレクターの組み合わせで実現できますが、容易ではありません。表の背景色です。この属性は、列の各セルの背景色を定義します。 6桁の16進数の RGB コードの前に '#
' が付いた形です。定義済みの色キーワードのうちの一つも使用できます。
同様の効果を得るには、 CSS の {{cssxref("background-color")}} プロパティを使用してください。
char
ではない場合は、この属性は無視されます。char
属性で指定された揃え文字からその列のデータをオフセットする文字数を示します。baseline
: テキストを可能な限りセルの下端に近づけますが、下端ではなく文字のベースラインに揃えます。文字がサイズ全体に渡る場合は、 bottom
と同じ効果になります。bottom
: テキストを可能な限りセルの下端に近づけて配置します。middle
: テキストをセルの中央部に置きます。top
: テキストを可能な限りセルの上端に近づけて配置します。<col>
要素を与えたセレクターに設定しようとしてはいけません。{{HTMLElement("td")}} 要素は <col>
要素の子孫ではないため、プロパティを継承しません。td:nth-child(an+b)
セレクターを使用してください。a は表内の列数、b は表内の列の位置を示す序数です。このセレクターの後でのみ vertical-align
プロパティを使用することができます。[colspan=n]
のような、十分な CSS 属性セレクターの組み合わせで実現できますが、容易ではありません。0*
も使用できます。これはグループ内の各列の幅を、列の内容物を保持するのに必要最小限の幅にします。5*
のような幅の相対値も使用できます。{{HTMLElement("table")}} ページに <col>
要素の使用例があります。
仕様書 | 状態 | 備考 |
---|---|---|
{{SpecName('HTML WHATWG', 'tables.html#the-col-element', '<col>')}} | {{Spec2('HTML WHATWG')}} | |
{{SpecName('HTML5 W3C', 'tabular-data.html#the-col-element', '<col>')}} | {{Spec2('HTML5 W3C')}} | |
{{SpecName('HTML4.01', 'struct/tables.html#h-11.2.4.2', '<col>')}} | {{Spec2('HTML4.01')}} | 初回定義 |
{{Compat("html.elements.col")}}
<col>
要素のスタイル設定に特に役立つであろう CSS プロパティと擬似クラス: