/[pub]/suikawiki/sw4data/ids/8/458.txt
Suika

Contents of /suikawiki/sw4data/ids/8/458.txt

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.16 - (hide annotations) (download)
Sun Dec 14 12:04:23 2008 UTC (16 years, 6 months ago) by wakaba
Branch: MAIN
Changes since 1.15: +4 -2 lines
File MIME type: text/plain
updated by (anon)

1 wakaba 1.2 [7] [[HTML]] ではいくつかの[[属性]]などで[[日時]]を表す文字列が用いられています。
2     そのほとんどは [[ISO 8601の日付形式]]に近いものですが、歴史的な理由により異なる書式を採用している文脈もあります。
3    
4 wakaba 1.3 [[HTML]] で定義されている[[日付形式]]には、次のものがあります。
5     - [[時刻]]
6     - [[月]]
7     - [[日付]]
8     - [[地方日時]]
9     - [[大域日時]]
10     - [[日付か時刻]]
11 wakaba 1.8 - [[週]]
12 wakaba 1.11 - [CODE(DOMa)@en[[[lastModified]]]] の書式 → [CODE(DOMa)@en[[[lastModified]]]] の項を参照。
13 wakaba 1.3
14 wakaba 1.2 [8] 仕様書:
15     - [[HTML5]] <http://www.whatwg.org/specs/web-apps/current-work/#dates-and-times>
16    
17 wakaba 1.9 ;; [51] 本項では [[HTML5]] の定義に基づき説明しますが、
18     構文の定義や算法の定義は必ずしも仕様書の通りではありません。仕様書の規定と等価な別な表現で説明していることがあります。
19    
20 wakaba 1.2 * 定義
21    
22     [10] [DFN[[RUBYB[数字]@en[digit]]]]とは、
23 wakaba 1.4 [CODE(char)[[[U+0030]]]]〜[CODE(char)[[[U+0039]]]] の[[文字]]であって、
24 wakaba 1.2 [[十進数]]を表すために使われます [SRC@en[[[HTML5]]]]。
25    
26     [9] ある[[年]]のある[[月]]の[[日]]の数は、[[グレゴリオ暦]]に基づき、次のように定義されています
27     [SRC@en[[[HTML5]]]]。
28     - [[1月]]、[[3月]]、[[5月]]、[[7月]]、[[8月]]、[[10月]]、[[12月]]は、 '''31'''
29     - [[4月]]、[[6月]]、[[9月]]、[[11月]]は、 '''30'''
30     - [[2月]]は、
31     -- [[年]]が400で割り切れるか、または4で割り切れて100で割り切れないなら
32     ([[閏年]]なら)、 '''29'''
33     -- それ以外なら、 '''28'''
34    
35 wakaba 1.4 * 時刻
36    
37     [20] [DFN[[RUBYB[時刻]@en[time]]]]は、特定の[[時刻]]を表し、
38     [[時]]、[[分]]、[[秒]]、[[秒の小数部]]から成ります。[[時間帯]]の情報は持ちません。
39     [SRC@en[[[HTML5]]]]
40    
41     -[21] [CODE(ABNF)[[DFN[[RUBYB[妥当な時刻文字列]@en[valid time string]]]] := 2[[数字]] ":" 2[[数字]] [":" 2[[数字]] ["." 1*[[数字]] ] ] ]]
42     [SRC@en[[[HTML5]]]]
43     -- 1つ目の[[数字]]列は、[[時]]を表す 0〜23 の[[数]]
44     -- 2つ目の[[数字]]列は、[[分]]を表す 0〜59 の[[数]]
45     -- 3つ目の[[数字]]列は、[[秒]]の[[整数部]]を表す 0〜59 の[[数]] ([[秒]]が 0 の時だけ省略可能)
46     -- 4つ目の[[数字]]列は、[[秒]]の[[小数部]]を表す値 ([[秒]]が[[整数]]の時だけ省略可能)
47    
48     [23] [DFN[[RUBYB[時刻文字列の構文解析]@en[parse a time string]]]]
49     [SRC@en[[[HTML5]]]]:
50     = [[時刻部品の構文解析]]を行い、それが何も返さなかったら、何も返さないで終える
51     = [[文字列]]がそれで終わっていなければ、何も返さないで終える
52     = (1) で得られた[[時]]と[[分]]と[[秒]]を返す
53    
54     [24] [DFN[[RUBYB[時刻部品の構文解析][parse a time component]]]]
55     [SRC@en[[[HTML5]]]]:
56     = [[文字列]]が[[正規表現]] [CODE(regexp)[([[数字]]{2}):([[数字]]{2})(?::([[数字]]{2}(?:\.[[数字]]+)?))?]]
57     に[[一致]]しない場合、何も返さず終わる
58     = $1 を[[十進数]]として解釈したものを[[時]]とする
59     = $2 を[[十進数]]として解釈したものを[[分]]とする
60     = $3 を[[十進数]]として解釈したものを[[秒]]とする ($3 がない場合、 0 とする)
61     = [[時]]が 0〜23 でない場合、何も返さない
62     = [[分]]が 0〜59 でない場合、何も返さない
63     = [[秒]]が 60 [[未満]]の[[正数]]でない場合、何も返さない
64     = [[時]]と[[分]]と[[秒]]を返す
65    
66 wakaba 1.10
67     ** 文脈
68    
69     [54] [CODE(HTMLa)@en[[[type]]]] が [CODE(HTML)@en[[[time]]]] の [CODE(HTMLe)@en[[[input]]]]
70     [[要素]]で使われます。
71    
72 wakaba 1.2 * 月
73    
74     [11] [DFN[[RUBYB[月]@en[month]]]]は、[[グレゴリオ暦]]上の[[日付]]を表します。ただし、
75     [[月]]は[[時間帯]]の情報を持ちませんし、[[日付]]の精度は[[年]]と[[月]]だけで、[[日]]は特定しません。
76     [SRC@en[[[HTML5]]]]
77    
78     - [13] [CODE(ABNF)[[DFN[[RUBYB[妥当な月]@en[valid month]]]] := 4*[[数字]] "-" 2[[数字]]]]
79     [SRC@en[[[HTML5]]]]
80     -- 1つ目の[[数字]]列は、[[年]]を表す[[正数]]
81 wakaba 1.3 -- 2つ目の[[数字]]列は、[[月]]を表す 1〜12 の[[数]]
82 wakaba 1.2
83     [14] [DFN[[RUBYB[月文字列の構文解析]@en[parse a month string]]]]
84     [SRC@en[[[HTML5]]]]:
85     = [[月部品の構文解析]]を行い、それが何も返さなかったら、何も返さないで終える
86     = [[文字列]]がそれで終わっていなければ、何も返さないで終える
87     = (1) で得られた[[年]]と[[月]]を返す
88    
89 wakaba 1.3 [15] [DFN[[RUBYB[月部品の構文解析][parse a month component]]]]
90 wakaba 1.2 [SRC@en[[[HTML5]]]]:
91 wakaba 1.4 - 与えられた[[文字列]]が[[正規表現]] [CODE(regexp)[([[数字]]{4,})-([[数字]]{2})]]
92 wakaba 1.2 に[[一致]]すれば、
93     -= $1 を[[十進数]]として解釈したものを[[年]]とする
94     -= $2 を[[十進数]]として解釈したものを[[月]]とする
95     -= [[年]]が 0 なら、何も返さない
96 wakaba 1.3 -= [[月]]が 1〜12 でなければ、何も返さない
97 wakaba 1.2 -= そうでない場合、[[年]]と[[月]]を返す
98     - そうでない場合、何も返さない
99 wakaba 1.3
100 wakaba 1.10 ** 文脈
101    
102     [52] [CODE(HTMLa)@en[[[type]]]] が [CODE(HTML)@en[[[month]]]] の [CODE(HTMLe)@en[[[input]]]] [[要素]]で使用されます。
103    
104 wakaba 1.3 * 日付
105    
106     [16] [DFN[[RUBYB[日付]@en[date]]]]は、[[グレゴリオ暦]]上の[[日付]]を表します。
107     [[日付]]には[[年]]、[[月]]、[[日]]が含まれますが、[[時間帯]]は含まれません。
108     [SRC@en[[[HTML5]]]]
109    
110     -[17] [CODE(ABNF)@en[[DFN[[RUBYB[妥当な日付文字列]@en[valid date string]]]] := [[妥当な月文字列]] "-" 2[[数字]]]]
111     [SRC@en[[[HTML5]]]]
112     -- 最後の[[数字]]列は、[[年]]と[[月]]に基づく[[日]]の数 (>>9) [[以下]]の[[正数]]で、[[日]]を表す
113    
114     [18] [DFN[[RUBYB[日付文字列の構文解析]@en[parse a date string]]]]
115     [SRC@en[[[HTML5]]]]:
116     = [[日付部品の構文解析]]を行い、それが何も返さなかったら、何も返さないで終える
117     = [[文字列]]がそれで終わっていなければ、何も返さないで終える
118     = (1) で得られた[[年]]と[[月]]と[[日]]を返す
119    
120     [19] [DFN[[RUBYB[日付部品の構文解析][parse a date component]]]]
121     [SRC@en[[[HTML5]]]]:
122     = [[月部品の構文解析]]により、[[年]]と[[月]]を得る。何も返されなかった場合、何も返さず終わる
123 wakaba 1.4 = [[文字列]]の続きが[[正規表現]] [CODE(regexp)[-([[数字]]{2})]] に[[一致]]しない場合、何も返さず終わる
124 wakaba 1.3 = $1 を[[十進数]]として解釈したものを[[日]]とする
125 wakaba 1.4 = [[日]]が[[年]]と[[月]]に基づく[[日]]の数 (>>9) [[以下]]の[[正数]]でなければ、何も返さず終わる
126 wakaba 1.3 = [[年]]と[[月]]と[[日]]を返す
127 wakaba 1.2
128 wakaba 1.10 ** 文脈
129    
130     [53] [CODE(HTMLa)@en[[[type]]]] が [CODE(HTML)@en[[[date]]]] の [CODE(HTMLe)@en[[[input]]]]
131     [[要素]]で使われます。
132    
133 wakaba 1.5 * 地方日時
134    
135     [25] [DFN[[RUBYB[地方日時]@en[local date and time]]]]は、
136     [[グレゴリオ暦]]上の[[日時]]を表します。
137     [[年]]、[[月]]、[[日]]、[[時]]、[[分]]、[[秒]]、[[秒の小数部]]から成ります。
138     [[時間帯]]の情報は含みません。
139     [SRC@em[[[HTML5]]]]
140    
141     -[26] [CODE(ABNF)@en[[DFN[[RUBYB[妥当な地方日時文字列]@en[valid local date and time string]]]] := [[妥当な日時文字列]] 'T' [[妥当な時刻文字列]]]]
142     [SRC@em[[[HTML5]]]]
143     -- 「T」は[[大文字]]でなければなりません。
144    
145     [27] [DFN[[RUBYB[地方日時文字列の構文解析]@en[parse a local date and time string]]]] [SRC@en[[[HTML5]]]]:
146     = [[日付部品の構文解析]]により、[[年]]と[[月]]と[[日]]を得る。何も返されなかった場合、
147     何も返さず終わる
148     = [[文字列]]の次の[[文字]]が[[大文字]]の「[CODE(char)[[[T]]]]」でない場合、
149     何も返さず終わる
150     = [[時刻部品の構文解析]]により、[[時]]と[[分]]と[[秒]]を得る。何も返されなかった場合、
151     何も返さず終わる
152     = [[文字列]]がそれで終わっていなければ、何も返さず終わる
153     = [[年]]と[[月]]と[[日]]と[[時]]と[[分]]と[[秒]]を返す
154    
155 wakaba 1.10
156     ** 文脈
157    
158     [55] [CODE(HTMLa)@en[[[type]]]] が [CODE(HTML)@en[[[datetime-local]]]] の [CODE(HTMLe)@en[[[input]]]]
159     [[要素]]で使われます。
160    
161 wakaba 1.6 * 時間帯
162    
163     [28] [[大域日時]]や[[日付や時刻]]には[RUBYB[[[時間帯]]]@en[timezone]]の情報を含めることができます。
164     [[時間帯]]には、[[時]]と[[分]]の情報が含まれます。
165    
166     - [CODE(ABNF)@en[[DFN[時間帯]] := '[[Z]]' / ("[[+]]" / "[[-]]") 2[[数字]] ":" 2[[数字]]]]
167     [SRC@en[[[HTML5]]]]
168     -- 「[CODE(char)[[[Z]]]]」は [[UTC]] を表す
169     -- 1つ目の[[数字]]列は[[時差]]の[[時]]を表す 0〜23 の[[数]]
170     -- 2つ目の[[数字]]列は[[時差]]の[[分]]を表す 0〜59 の[[数]]
171    
172     [29] [DFN[[RUBYB[時間帯部品の構文解析]@en[parse a timezone component]]]] [SRC@en[[[HTML5]]]]:
173     = 次の[[文字]]が[[大文字]]の「[CODE(char)[[[Z]]]]」 であれば、
174     [[時]]として 0、[[分]]として 0 を返して終わる
175     = [[文字列]]が[[正規表現]] [CODE(regexp)[([+-]2[[数字]]):(2[[数字]])]] に[[一致]]しない場合、
176     何も返さずに終わる
177     = $1 を[[十進数]]として解釈したものを[[時]]とする
178     = $2 を[[十進数]]として解釈したものを[[分]]とする
179     = [[時]]が -23〜23 でない場合、何も返さない
180     = [[分]]が 0〜59 でない場合、何も返さない
181     = [[時]]と[[分]]を返す
182    
183     [30] [[RFC 3339の日付形式]]などでは [[-00:00]] に[[時間帯]]不明という意味が与えられていますが、
184     [[HTML]] の[[日付形式]]では特にそのような規定はありません。
185    
186     * 大域日時
187    
188     [31] [DFN[[RUBYB[大域日時]@en[global date and time]]]]は、
189     [[グレゴリオ暦]]上の[[日時]]を表します。
190     [[年]]、[[月]]、[[日]]、[[時]]、[[分]]、[[秒]]、[[秒の小数部]]、[[時間帯]]から成ります。
191     [SRC@em[[[HTML5]]]]
192    
193     -[32] [CODE(ABNF)@en[[DFN[[RUBYB[妥当な大域日時文字列]@en[valid global date and time string]]]] := [[妥当な日時文字列]] '[[T]]' [[妥当な時刻文字列]] [[時間帯]]]]
194     [SRC@em[[[HTML5]]]]
195     -- 「[CODE(char)[[[T]]]]」は[[大文字]]でなければなりません。
196    
197 wakaba 1.7 [33] [DFN[[RUBYB[大域日時文字列の構文解析]@en[parse a global date and time string]]]] [SRC@en[[[HTML5]]]]:
198 wakaba 1.6 = [[日付部品の構文解析]]により、[[年]]と[[月]]と[[日]]を得る。何も返されなかった場合、
199     何も返さず終わる
200     = [[文字列]]の次の[[文字]]が[[大文字]]の「[CODE(char)[[[T]]]]」でない場合、
201     何も返さず終わる
202     = [[時刻部品の構文解析]]により、[[時]]と[[分]]と[[秒]]を得る。何も返されなかった場合、
203     何も返さず終わる
204     = [[時間帯部品の構文解析]]により、[[時間帯]]の[[時]]と[[分]]を得る。何も返されなかった場合、
205     何も返さず終わる
206     = [[文字列]]がそれで終わっていなければ、何も返さず終わる
207 wakaba 1.9 = [[年]]~[[秒]]を、[[時間帯]]の情報を使って [[UTC]] に換算する
208 wakaba 1.6 = [[年]]と[[月]]と[[日]]と[[時]]と[[分]]と[[秒]]と[[時間帯]]の[[時]]と[[分]]を返す
209    
210 wakaba 1.10
211     ** 文脈
212    
213     [56] [CODE(HTMLa)@en[[[type]]]] が [CODE(HTML)@en[[[datetime]]]] の [CODE(HTMLe)@en[[[input]]]]
214     [[要素]]で使われます。
215    
216     [57] [CODE(HTMLe)@en[[[ins]]]] [[要素]]や [CODE(HTMLe)@en[[[del]]]] [[要素]]の
217     [CODE(HTMLa)@en[[[datetime]]]] [[属性]]で使われます。
218    
219 wakaba 1.7 ** 例
220    
221     [34] [CODE(HTML example)[0037-12-13T00:00Z]] [SRC@en[[[HTML5]]]]
222    
223     [[ローマ皇帝]][[ネロ]]の[[誕生日]] ([[ユリウス暦]]37年12月15日の[[グレゴリオ暦]]換算)
224     の[[真夜中]]を表します。なお、
225     [CODE(HTML bad example)[[[37-12-13]]]] は[[年]]が4桁に満たないので、
226     [[妥当な大域日時文字列]]ではありません。
227    
228     [35] [CODE(HTML example)[1979-10-14T12:00:00.001-04:00]] [SRC@en[[[HTML5]]]]
229    
230     [[北米東海岸]]の[[夏時刻]]中の1979年10月14日の[[正午]]から1[[ミリ秒]]後を表します。
231    
232     [36] [CODE(HTML example)[8592-01-01T02:09+02:09]] [SRC@en[[[HTML5]]]]
233    
234     将来の[[時刻]]です。端数の[[時間帯]]は現在[[地球上]]では用いられていませんが、
235     仕様上は認められています。
236    
237 wakaba 1.9 * 日付か時刻
238    
239     [47] [DFN[[RUBYB[日付か時刻の文字列]@en[date or time string]]]]は、
240     [[日付]]か[[時刻]]か[[大域日時]]のいずれかです。
241     [SRC@en[[[HTML5]]]]
242    
243 wakaba 1.13 -[48] [CODE(ABNF)[[DFN[[RUBYB[妥当な日付か時刻の文字列]@en[valid date or time string]]]] := [[妥当な日付文字列]] / [[妥当な時刻文字列]] / [[妥当な大域日時文字列]]]]
244     -[49] [CODE(ABNF)[[DFN[[RUBYB[妥当な内容中の日付か時刻の文字列]@en[valid date or time string in content]]]] := *[[White_Space]] [[妥当な日付か時刻の文字列]] *[[White_Space]]]]
245 wakaba 1.9
246     [50] [DFN[[RUBYB[日付か時刻の文字列の構文解析][parse a date or time string]]]] [SRC@en[[[HTML5]]]]:
247 wakaba 1.10 = 先頭と末尾から [[White_Space]] を除去する (「内容中」の場合のみ)
248 wakaba 1.9 = [[大域日時文字列の構文解析]]が値を返すなら、それを返して終わる
249     = [[日付の構文解析]]が値を返すなら、それを返して終わる
250     = [[時刻の構文解析]]が値を返すなら、それを返して終わる
251     = 何も返さないで終わる
252    
253 wakaba 1.10
254     ** 文脈
255    
256     [59] [CODE(HTMLe)@en[[[time]]]] [[要素]]で使われます。
257     [CODE(HTMLa)@en[[[datetime]]]] [[属性]]では[[妥当な日付か時刻の文字列]]、
258     [[内容]]では[[妥当な内容中の日付か時刻の文字列]]の定義が用いられます。
259    
260 wakaba 1.8 * 週
261    
262     [43] [DFN[[RUBYB[週]@en[week]]]]は、
263     [RUBYB[[[週年]]]@en[week‐year]]番号と週番号から成り、
264     7日間の期間を表します。 [SRC@en[[[HTML5]]]]
265    
266     [[週]]は次のようなものです [SRC@en[[[HTML5]]]]。
267     - 1つの[[週年]]は52か53の[[週]]を含みます。
268     -- [[木曜日]]から始まる[[年]]と[[閏年]]は '''53''' です。
269     -- それ以外の[[年]]は '''52''' です。
270 wakaba 1.15 -- なお、[[週年]]の最後の[[日]]を含む[[週]]の番号が[DFN[[RUBYB[最終日の週番号]@en[week number of the last day]]]]です。
271 wakaba 1.8 - [[週]]は7日間の期間です。
272     - [[1970年]]の 1 番の[[週]]は[[1969年]]12月29日 ([[月曜日]]) に始まります。
273    
274     ;; [[グレゴリオ暦]]における[[年]]の中で最初の[[木曜日]]を含む[[週]]が、
275     ある[[週年]]の最初の[[週]]になります。 [SRC@en[[[HTML5]]]]
276 wakaba 1.15
277     [61] つまり、[[週]]は[[月曜日]]に始まり[[日曜日]]に終わります。
278    
279 wakaba 1.16 [62] [[1月1日]]が[[月曜日]]〜[[木曜日]]なら[[1月1日]]はその[[年]]と同じ[[週年]]の最初の[[週]]に属しますが、
280     [[金曜日]]〜[[日曜日]]なら[[年]]の1つ前の[[週年]]の最後の[[週]]に属します。
281     [[12月29日]]〜[[12月31日]]は次の[[年]]と同じ[[週年]]に属する可能性があります。
282     [[1月1日]]〜[[1月3日]]は前の[[年]]と同じ[[週年]]に属する可能性があります。
283 wakaba 1.8
284 wakaba 1.13 -[44] [CODE(ABNF)[[DFN[[RUBYB[妥当な週文字列]@en[valid week string]]]] := 4*[[数字]] '-W' 2[[数字]]]]
285 wakaba 1.8 [SRC@en[[[HTML5]]]]
286     -- 1つ目のの[[数字]]列は[[週年]]を表す[[正数]]
287     -- 2つ目の[[数字]]列は[[週]]を表す[[最終日の週番号]][[以下]]の[[正数]]
288    
289     [45] [DFN[[RUBYB[週文字列の構文解析]@en[parse a week string]]]] [SRC@en[[[HTML5]]]]:
290     = 与えられた[[文字列]]''全体''が[[正規表現]] [CODE(regexp)[([[数字]]{4,})-W([[数字]]{2})]]
291     に[[一致]]しない場合、何も返さないで終わる
292     = $1 を[[十進数]]として解釈したものを[[週年]]とする
293     = $2 を[[十進数]]として解釈したものを[[週]]とする
294     = [[週年]]が 0 なら、何も返さないで終わる
295     = [[週]]が 1〜[[最終日の週番号]] でなければ、何も返さないで終わる
296     = [[週年]]と[[年]]を返す
297 wakaba 1.10
298    
299     ** 文脈
300    
301     [58] [CODE(HTMLa)@en[[[type]]]] が [CODE(HTML)@en[[[week]]]] の [CODE(HTMLe)@en[[[input]]]]
302     [[要素]]で使われます。
303 wakaba 1.8
304     * 暦法との関係
305    
306     ** 過去の日付
307 wakaba 1.2
308     [12] [[HTML]] は[[グレゴリオ暦]] (だけ) を採用しています。[[グレゴリオ暦]]が採用される以前の[[日付]]も表すことができますが、
309     [[グレゴリオ暦]]を過去に延長した場合に相当する[[日付]]を使って表されます
310 wakaba 1.14 ([[先発グレゴリオ暦]] (proleptic グレゴリオ暦) などと呼ばれます)。
311 wakaba 1.4
312 wakaba 1.7 [39] [[年]]は[[正数]]のみを指定できます。0年や負の年は認められていません。
313    
314 wakaba 1.8 ** 将来の日付
315 wakaba 1.7
316     [37] 現在の版の [[HTML5]] では、[[年]]の桁数が4桁以上で無制限とされており、[[1万年問題]]は存在しません。
317    
318     [38] 過去の版の [[HTML5]] 案や [[Web Forms 2.0]] や [[HTML4]] では[[年]]は4桁に制限されていました。
319 wakaba 1.8
320     ** 閏秒
321    
322     [22] [[HTML]] の[[日付形式]]は[[閏秒]]に対応していません。[[秒]]の部分に 60 や 61
323     を使うことは認められていません。
324 wakaba 1.7
325     * 歴史
326 wakaba 1.9
327     [46] [[HTML]] の[[日付形式]]は、 [[HTML 4.0]] で [CODE(HTMLa)@en[[[datetime]]]]
328     [[属性]]が導入されたことではじめて規定され、後に [[Web Forms 2.0]] と [[HTML5]]
329     により拡張され現在に至っています。
330 wakaba 1.7
331     ** [CODE(SGML)[%Datetime;]] 型 (HTML4/XHTML1)
332 wakaba 1.1
333     [1] [[HTML 4]] の [DFN[[CODE(SGML)[%Datetime]]]] 型は、
334     [[W3C-DTF]] の2番目に長い (秒未満までは表現できない)
335     形式です。
336    
337     [6] 仕様書:
338     - [[HTML 4]]
339     -- <IW:HTML4:"types.html#type-datetime">
340     -- [[厳密DTD]] <IW:HTML4:"sgml/dtd.html#Datetime">
341     -- [[移行用DTD]] <IW:HTML4:"sgml/loosedtd.html#Datetime">
342     -[[XHTML 1.0]]
343     -- [CSECTION[A.1.1. XHTML-1.0-Strict]]
344     <http://www.w3.org/TR/2002/REC-xhtml1-20020801/dtds.html#dtdentry_xhtml1-strict.dtd_Datetime>
345     -- [CSECTION[A.1.2. XHTML-1.0-Transitional]]
346     <http://www.w3.org/TR/2002/REC-xhtml1-20020801/dtds.html#dtdentry_xhtml1-transitional.dtd_Datetime>
347     -- [CSECTION[A.1.3. XHTML-1.0-Frameset]]
348     <http://www.w3.org/TR/2002/REC-xhtml1-20020801/dtds.html#dtdentry_xhtml1-frameset.dtd_Datetime>
349     - [[XHTML m12n]]
350     --[CSECTION[4.3. Attribute Types]]
351     <IW:XHTML1m12n:"abstraction.html#dt_Datetime">
352    
353     [5]
354     :[[引数実体名]]:[CODE(SGML)[%Datetime]] ([[HTML 4]], [[XHTML 1.0]])
355     :抽象属性型名:[CODE[Datetime]] ([[XHTML m12n]])
356     :属性型名:[Q[datetime]] ([[HTML 4]])
357     :[[SGML]] [[属性型]]:[CODE(SGML)[[[CDATA]]]]
358     :[[XML]] [[属性型]]:[CODE(XML)[[[CDATA]]]]
359     :大文字・小文字:区別あり
360    
361     [2] 大文字・小文字は区別されます。
362     [CODE(HTML)[T]] と [CODE(HTML)[Z]] が使われ得ますが、
363     いずれも大文字でなければなりません。
364    
365     [3] 時・分・秒が得られない時は、 [CODE(HTML)[00]]
366     としてもよいことになっています。
367     閏秒の 60秒は W3C‐DTF では表現できません。
368    
369     [4]
370     [CODE(HTMLe)[[[ins]]]] 要素や [CODE(HTMLe)[[[del]]]] 要素の [CODE(HTMLa)[[[datetime]]]] 属性が [CODE(SGML)[%Datetime]] 型です。
371    
372 wakaba 1.7 ** HTML5 案
373    
374     [40] 現在 [[HTML]] で定義されている[[日付形式]]のほとんどは、 [[Web Forms 2.0]]
375     で[[日時]]関係の[[フォーム制御子]]を実現するために導入されました。
376 wakaba 1.1
377 wakaba 1.7 [41] [[HTML5]] では [[HTML4]] から引き継いだ [CODE(HTMLe)@en[[[ins]]]] [[要素]]や
378     [CODE(HTMLe)@en[[[del]]]] [[要素]]の [CODE(HTMLa)@en[[[datetime]]]] [[属性]]のための[[日付形式]]
379     (現在の[[大域日時]]) に加え、
380     [CODE(HTMLe)@en[[[time]]]] [[要素]]のための[[日付や時刻]]の書式が導入されました。
381 wakaba 1.1
382 wakaba 1.7 [42] その後 [[Web Forms 2.0]] が [[HTML5]] に統合された際に、これらの定義は整理され、
383     本稿で紹介したような形になりました。この時、[[1万年問題]]への対応など細かい点が改められています。
384 wakaba 1.1
385 wakaba 1.12 * 関連
386    
387     [60] [[時刻]]でなく[[時間]]を表すものとしては、
388     [CODE(HTMLa)@en[[[http-equiv]]]] [[属性]]が [CODE(HTTP)@en[[[Refresh]]]]
389     の場合の [CODE(HTMLa)@en[[[content]]]] [[属性値]]の書式 ([[秒]]数を指定) があります。
390    
391     以前の [[HTML5]] 案には [CODE(HTMLe)@en[[[audio]]]] [[要素]]や [CODE(HTMLe)@en[[[video]]]] [[要素]]に[[媒体]]中の[[時間]]的位置を表す[[内容属性]]がありましたが、
392     既に削除されています。
393     [[秒]]数を返す [[DOM属性]]は削除されずに残っています。

admin@suikawiki.org
ViewVC Help
Powered by ViewVC 1.1.24