* th 要素・td 要素 headers 属性 (HTML, XHTML 1)
[1] [[HTML]] の [CODE(HTMLe)[[[th]]]] 要素および [CODE(HTMLe)[[[td]]]]
要素の [DFN[[CODE(HTMLa)[headers]] 属性]]は、
当該のデータこまの見出し情報を示します。
仕様書: [[HTML 4]]
- [CODE(HTMLa)[headers]]
- 11.4.1 Associating header information with data cells
[2] [Q[現在の''データ''こまの見出し情報を提供]]する割には、
[CODE(HTMLe)[th]] 要素にもこの属性があったりします。
[[#comment]]
** 属性値
[3] この属性の値は [CODE(SGML)[[[IDREFS]]]] です。
それぞれの値はこまの名前 ([CODE(HTMLa)[[[id]]]]) です。
[Q[こまの名前]]であって[Q[見出しこまの名前]]とは特に限定されていません。
常識的には見出しこまを指定するものですが、 HTML 4
的には見出しこまとデータこまをあまり区別する気がないようなので、
本当に[Q[こまの名前]]なのかもしれません。
[4] HTML 4 仕様書の記号によれば、この属性の値は大文字・小文字を区別します。
SGML 的には [CODE(SGML)[IDREFS]] で、 HTML 4 は
[CODE(SGML)[[[NAMECASE]] [[GENERAL]] YES]]
なので、属性値は自動的に大文字に統一されます。
というあたり、なんだかなぁ。 ([[噂のID問題]]参照。)
[6] この属性は省略可能です。
[CODE(HTMLa)[headers]] 属性がなく、 [CODE(HTMLa)[[[scope]]]]
属性の影響下にもないこまの見出しは、 >>10 の算法で求められます。
[[#comment]]
*** 見出し情報検出算法
[10] [CODE(HTMLa)[headers]] がなく、 [CODE(HTMLa)[scope]]
の適用下にもないこまの見出し情報は、次の算法により求めても構いません。
仕様書: HTML 4 11.4.3 Algorithm to find heading information
[11]
= 空の見出しこま並びを用意する
= こまの位置から左に向かって行見出しこまを探す
-- 見出しこまが見つかれば、見出しこま並びにそのこまを入れる
-- 見出しこま並びでの並び順は[[文書順]] (左から右へ)
-- 見出しこまを過ぎてデータこまが見つかればこの方向は探索終了
-- 見出しこまが [CODE(HTMLa)[[[headers]]]] 属性を持っていれば、
=== 見出しこま並びに [CODE(HTMLa)[headers]] 参照こま群を挿入
=== この方向は探索終了
-- 表の端まできたらこの方向は探索終了
= こまの位置から上に向かって列見出しこまを探す
-- 見出しこまが見つかれば、見出しこま並びに (列見出しの後に) そのこまを入れる
-- 見出しこま並びでの並び順は[[文書順]] (上から下へ)
-- 見出しこまを過ぎてデータこまが見つかれば探索終了
-- 見出しこまが [CODE(HTMLa)[[[headers]]]] 属性を持っていれば、
=== 見出しこま並びに [CODE(HTMLa)[headers]] 参照こま群を挿入
=== 探索終了
-- 表の端まできたら探索終了
- ただし、 [CODE(HTMLa)[[[axis]]]] を有するこまは見出しこまとして扱う
([[表方向性]]が左から右の場合。)
[12] 見出しこまが [CODE(HTMLa)[headers]] を持っているときにこま群をどこに挿入するのか
HTML 4 仕様書にはちゃんとかかれていません (前に? 後ろに?)。
またぎ ([CODE(HTMLa)[[[rowspan]]]]・[CODE(HTMLa)[[[colspan]]]])
こま対策も抜けています。
[[#comment]]
** レンダリング
[5] HTML 4 仕様書によれば、著者は通常、
非 [[視覚的UA]] がデータこまについての見出し情報
(例: こま情報の前に読まれる見出し情報) をレンダリングするのを助けるために
[CODE(HTMLa)[headers]] 属性を使いますが、
[[スタイル・シート]]とあわせて使っても構わないそうです。
[[#comment]]
** 他との関係
[8] 見出しこま側で [CODE(HTMLa)[[[scope]]]] 属性を使うことができます。
[CODE(HTMLa)[scope]] と [CODE(HTMLa)[headers]] は用途としては同じものですが、
データこま側に使う [CODE(HTMLa)[headers]] 属性の方が複雑な表にも対応できます。
(しかしほとんどの場合、 [CODE(HTMLa)[scope]] を使えば十分です。)
[[#comment]]
** 例
[7]
[PRE(HTML)[
Cups of coffee consumed by each senator
Name |
Cups |
Type of Coffee |
Sugar? |
T. Sexton |
10 |
Espresso |
No |
J. Dinnen |
5 |
Decaf |
Yes |
]PRE]
(HTML 4 仕様書より)
レンダリング例:
[PRE[
Caption: Cups of coffee consumed by each senator
Summary: This table charts the number of cups
of coffee consumed by each senator, the type
of coffee (decaf or regular), and whether
taken with sugar.
Name: T. Sexton, Cups: 10, Type: Espresso, Sugar: No
Name: J. Dinnen, Cups: 5, Type: Decaf, Sugar: Yes
]PRE]
[9] >>7 の例のような単純な構造の表では、
[CODE(HTMLa)[headers]] 属性の代わりに [CODE(HTMLa)[[[scope]]]]
属性を使うことができます。
[PRE(HTML)[
Cups of coffee consumed by each senator
Name |
Cups |
Type of Coffee |
Sugar? |
T. Sexton |
10 |
Espresso |
No |
J. Dinnen |
5 |
Decaf |
Yes |
]PRE]
この場合 >>7 とまったく同じレンダリング結果が期待できます。
[13]
[CITE@en[General Electric : Our Company : News]] ([[General Electric]] 著, [CODE[2007-05-26 17:23:46 +09:00]] 版)
実世界例
([[名無しさん]])
[14]
[CITE@en[Tide Tables - Broads Authority]] ([[http://www.broads-authority.gov.uk/]] 著, [CODE[2007-05-26 17:23:45 +09:00]] 版)
実世界例
([[名無しさん]])
[[#comment]]
** メモ
[15]
[CITE@en[WebAIM: E-mail List Archives]] ([CODE[2007-05-26 17:23:43 +09:00]] 版)
([[名無しさん]])
[16]
[CITE[6 Web-Based Information and Applications Accessibility Guidelines]] ([CODE[2007-05-26 17:23:42 +09:00]] 版)
誤って [CODE(HTMLa)@en[[[header]]]] とした解説
([[名無しさん]])
[17]
[CITE[nsf.gov - Web Development Policy and Standards Manual: Example 15: Tables - US National Science Foundation (NSF)]] ([CODE[2007-05-26 17:35:39 +09:00]] 版)
>
[PRE(HTML invalid example code)[
BIO |
10 |
25 |
]PRE]
なんだこりゃ。
([[名無しさん]] [WEAK[2007-05-26 08:37:52 +00:00]])
[18]
[CITE[Section 508,§1194.22, Rule H - Section 508 - NOAA's National Weather Service]] ([CODE[2007-01-17 22:30:30 +09:00]] 版)
[CODE(HTMLa)@en[[[headers]]]] が [CODE(HTMLe)@en[[[span]]]] を指している。 [[HTML 4]] でいう
[CODE(HTMLa)@en[[[axis]]]] と合体させたような使い方がしたかったらしいが・・・。
([[名無しさん]] [WEAK[2007-05-26 08:39:37 +00:00]])
[19]
[CITE@en[Re: Complex Table Examples]] ([[Ian Hickson]] 著, [CODE[2007-05-18 07:08:17 +09:00]] 版)
([[名無しさん]] [WEAK[2007-05-26 08:51:46 +00:00]])
[20]
[CITE@en-gb[Juicy Studio: The HTML Scope/Headers Debate]] ([TIME[2007-06-03 09:34:57 +09:00]] 版)
([[名無しさん]] [WEAK[2007-06-03 00:47:18 +00:00]])
[[#comment]]
* メモ