/
2.txt
245 lines (178 loc) · 12.8 KB
/
2.txt
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
[1] [DFN[[CODE(HTTP)@en[[[Content-Script-Type:]]]]]] は、
[[文書]]の既定の[[スクリプト言語]]を指定するものとして提案されていました。
[44] 00年代には一部で実装され、使われていましたが、ほとんど意味がなく、
現在では使われていません。
* 代替
[48] 古い [[HTML文書]]では [CODE(HTML)@en[[[<meta http-equiv>]]]] により
[CODE(HTTP)@en[[[Content-Script-Type]]]] が指定されているかもしれませんが、
今となっては全く意味がありませんから、削除して構いません。
[SEE[ [[スクリプトのMIME型]] ]]
* 構文
[27] この欄の[[本体]]には、 [CODE(SGML)[%[[ContentType]]]]
を指定します [SRC[HTML 4 18.2.2.1]]。
[26] この欄は、 [[HTTP]] の頭欄としても、 [[HTML]] の [CODE(HTMLe)[[[meta]]]]
要素としても指定できます。また、どちらの方法でも、複数指定できます。
しかし、実際に有効なのは一番最後のものだけであり、
2通りの方法で指定されている時は、 [CODE(HTMLe)[meta]] 要素の方が優先されます。
[SRC[HTML 4 18.2.2.1]]
HTTP の規定によれば、同じ名前の頭欄を複数指定できるのは、
欄本体が値を[[読点]]で分離した[[並び]]として定義されている場合だけです。
ですから、 HTML 4 仕様書には明記されていませんが、
実際には欄本体は [CODE(SGML)[%ContentType]] の読点分離並びとなります。
[28] HTML 文書が[[内在事象]]属性を持っているのに
[CODE(HTTP)[Content-Script-Type]] により既定スクリプト言語が指定されていないのは[RUBYB[不正] [incorrect]]です。
[[UA]] はそれでも適当に解釈を試みて構いませんが、そうする必要はありません。
また、[[著述工具]]は既定スクリプト言語情報を生成して文書が不正にならないようにするべきです。
[SRC[HTML 4 18.2.2.1]]
[[#comment]]
* 歴史
** HTML4
[REFS[
- [2] [[HTML 4]]
-- [CSECTION[The default scripting language]]
<http://www.w3.org/TR/html4/interact/scripts.html#default-script>
]REFS]
[15] [CODE(HTTP)[Content-Script-Type]] がはじめて登場したのは
後に HTML 4 の一部となる作業原案の一つ
[CITE[Client-side Scripting and HTML]] <http://www.w3.org/TR/WD-script-960627>
でした。これ以前は、 [CODE(HTTP)[[[Content-Script-Language]]]]
という名前でまったく同じ機能を持っていました。
[16] その後の <http://www.w3.org/TR/WD-script-960808> までは、 JavaScript
が既定値でした。
[17] その次の <http://www.w3.org/TR/WD-script-970314> は、
[Q[多くの [[UA]] は JavaScript を既定値とする]]と弱くなっています。
[18] その次の <http://www.w3.org/TR/WD-html40-970708/interact/scripts.html> では、
[Q[何らかの指定が必須である]]とされています。
[19] 一年経って随分かたくなりました(w
[20] 同じ現象は [CODE(HTTP)[[[Content-Style-Type]]]] でも同時期に起こってます。
HTML として全体的に、現状への妥協というか、
とにかくなんでもいいから標準の確立を急いだ1996年の [[HTML 3.2]] の世代から、
現状を受け入れつつも次の時代への展望を示す1998年の [[HTML 4]]
の時代への過渡期とでもいいましょうか。なんとも興味深いところです。
[9] [[SVG]] には、 [CODE(XMLa)[[[contentScriptType]]]] 属性が
[CODE(XMLe)[[[svg]]]] 要素に存在します。
(''Scripting - SVG'' <http://www.w3.org/TR/SVG/script#ContentScriptTypeAttribute>)
[10] >>9 古い draft ではこれの次の優先順位で [CODE(HTTP)[Content-Script-Type:]]
欄が使われていましたが、削除されました。
(''Scripting''
<http://www.w3.org/TR/1999/WD-SVG-19991203/script.html#DefaultScriptingLanguage>)
[11] >>10 なお、これの省略時の既定値は [CODE(MIME)[[[text/ecmascript]]]]
でした。 (既定値の規定も削除されました。)
[46] [[RFC 4229]] は [[HTML4]] を出典に状態「[[標準]]」で [[IANA登録簿]]に登録しています
[SRC[>>45]]。
[REFS[
- [45] [CITE@en[RFC 4229 - HTTP Header Field Registrations]] ([TIME[2014-11-02 18:53:20 +09:00]] 版) <http://tools.ietf.org/html/rfc4229#section-2.1.30>
]REFS]
[50] [[CEA-2014-B]]
* 実装
[29] 既定スクリプト言語が決定できない場合、 [[Mozilla]] 系は
[[JavaScript]] とし、 [[WinIE]] は [CODE(HTMLa)[[[language]]]]
[[属性]]や [[URI scheme]] 名 ([CODE(char)[:]] を含む。)
のような文字列の有無で判定し、それがなければ [[JScript]]
とするようです。
実際の文書は指定がない (実際には [[JavaScript]] である) ことが多かったですが、
最近は [CODE(HTMLe)[meta]] によって指定するものが増えてきています。
[25]
現時点で、 [[Gecko]] も [[WinIE6]] もこの[[頭欄]]は実装していないようです。
無視して [[JavaScript]] として実行しようとします。
(WinIE の場合には [CODE(HTMLa)[[[language]]]] 属性や、属性値のはじめの方の [CODE[vbs:]] のような記述が反映されますが。)
([[名無しさん]] [WEAK[2004-03-23 06:28:15 +00:00]])
[36]
[CITE[Bug 354630 – Intrinsic events not following <meta http-equiv="Content-Script-Type" content="application/x-python" /> directive]] ([CODE[2007-03-31 23:35:12 +09:00]] 版) <https://bugzilla.mozilla.org/show_bug.cgi?id=354630>
([[名無しさん]])
[[#comment]]
* 不思議解釈
[30]
[[欄本体]]が適当な値、たとえば ([CODE(MIME)@en[[[text/javascript]]]]
ではなく) [CODE@en[javascript]] でいいと嘘を布教している人がいます。
例:
- [31] [CITE@en[Scripts]] (2001年付け、 [[Jacques Steyn]] 著)
<http://knowsystems.com/markup/html/explain/scripts.html>:
[CODE@en[javascript]], [CODE@en[vbscript]], [CODE@en[tcl]]
が値に使えると根も葉もない嘘を教えようとしています。
- [32] [CITE[sample-1 pngアニメ]] (2004年1月付け、 [[Rei]] 著)
<http://word.starword.org/webpage_first/samp_01.html>:
[CODE@en[javascript]] を値にした例があり、
実際にこの [[HTML]] [[文書]]でも使っています。
ちなみにこの文書では [CODE(HTTP)@en[[[Content-Style-Type]]]]
に関する [CODE(HTMLe)@en[[[meta]]]] [[要素]]もあり、
そちらはなぜか正しく [CODE(MIME)@en[[[text/css]]]]
になっています。
- [33] [CITE[ネットで稼いじゃお♪♪>HTML MENU>○META(メタ)]]
(2005年7月付け)
<http://umi.chu.jp/html-meta.html>:
正しい例を示しながら、
[Q[スタイルシートは「CSS]・ジャバスプリクトは「javascript」でも大丈夫なようです。一般的な環境では特に指定しなくても認識されるみたいですが、指定して置いた方がいいみたいです。]]
などと無責任なことを述べています。
分かっていない人がいい加減なことを書いているのだとよくわかります。
[34]
更にまだある: <IW:Google:"\"meta http-equiv content-script-type content javascript\"">
([[名無しさん]] [sage])
[35]
>>33 と同じ著者による同じ内容のもの
[CITE[スタイルシート・スプリクトの言語を示す]]
(2003年7月付け)
<http://umi.chu.jp/CUTE-DIP/link/meta-4.html>
低品質なものはどれだけコピっても低品質ですよ[AA(fw)[wwww]]
([[名無しさん]] [sage])
[[#comment]]
* 例
- [7] [SAMP[Content-Script-Type: text/tcl]]
- [8] [SAMP[<meta http-equiv="Content-Script-Type" content="text/javascript">]]
- [14] [CODE(HTTP)[Content-Script-Type: [[application/x-javascript]]]]
- [21] [SAMP(HTTP)[Content-Script-Type: application/x-javascript; charset=[[euc-jp]]]]
[[#comment]]
* メモ
[3] 構文についての考察は [[Content-Style-Type:]] 欄の説明をご覧下さい。
欄の名前と値の適用対象が違う (スタイルではなくスクリプト) のと、
'''[CODE[Content-Script-Type:]] には既定値がない'''以外は同じです。
(既定のスクリプト言語については、 [[script]] 要素の説明を参照。)
[4] 値については、[[スクリプトの媒体型]]をご覧下さい。
[5] なお、 [[M$]] 独自拡張の [[HTML]] 仕様においては、殆ど全ての要素に [[language]]
属性が存在します。この定義は [CODE[script]] 要素の同属性と同じですが、当該要素の属性である
on[VAR[〜]] 属性の解釈に影響します。この属性値が継承されるのかは知りません。
[6] on[VAR[〜]] 属性そのものが[[非推奨]]なので、この欄もいずれ使われなくなるかもしれません。
- [22] この欄の欄本体は[[媒体型]]ですが、媒体型の [CODE(MIME)[[[charset]]]] 引数は省略することが慣習となっています。 (そもそも、やや狭義媒体型だけが許されるのか、引数も許されるのか規格上曖昧なのですけど、型によっては必須の引数もあるので、やや狭義媒体型しか指定できないとしたら欠陥規格です。)
- [23] [CODE(MIME)[charset]] 引数が省略された場合、 [CODE[Content-Type]] 欄であれば [[MIME]] なら [CODE(charset)[[[us-ascii]]]], [[HTTP]] では [CODE(charset)[[[iso-8859-1]]]] なのですけど、 [CODE(HTTP)[Content-Script-Type]] (や [CODE(HTTP)[Content-Style-Type]]) では既定値は「指定なし」です。この欄の用途は >>1 なのですが、つまり既に構文解析された HTML 文書の一部に [ABBR[CST]] が適用されるということです。つまり charset は意味を成さないのです。
- [24] とはいっても、 >>21 のような実例も確認されています。 >>23 の解釈は慣習的なものでしかないので、 >>14 も >>21 も間違いとはいえません。 [WEAK[(但し、 [CODE(MIME)[application/x-javascript]] の定義上 [CODE(MIME)[charset]] 引数の存在が意味を持つかという話もありますが、とりあえずその話は置いておきましょう。)]]
[[#comment]]
- [12] [[XUL]] とか [[XBL]] でも使えそうかなあ・・と思ったけど、 [[Mozilla]] は単に決め打ちしてるだけだしなあ。
- [13] 結局、使われない欄なんだろうなあ。 [[Strict]] 志向の人って script 属性なんてつかわなそうだし。
[37]
[CITE@ja[DUOGATE デュオゲート - 地図・乗換]] ([CODE[2007-07-04 19:53:31 +09:00]] 版) <http://eznavi.duogate.jp/map/?ctl=8121&box=off>
>
[PRE(HTML invalid example code)[
<META HTTP-EQUIV="Content-Script-Type" content="JavaScript">
]PRE]
([[名無しさん]])
[38]
[CITE@ja[無料動画:映画、海外ドラマ、アニメほか|パソコンテレビGyaO[ギャオ]]] ([CODE[2007-07-04 20:19:06 +09:00]] 版) <http://www.gyao.jp/>
>
[PRE(HTML invalid example code)[
<meta http-equiv="Content-script-Type" content="text/javascript; charset=Shift_jis" />
<meta http-equiv="Content-style-Type" content="text/css; charset=Shift_jis" />
]PRE]
([[名無しさん]])
[39]
[CITE@ja[無料動画:映画、海外ドラマ、アニメほか|パソコンテレビGyaO[ギャオ]]] ([TIME[2007-07-04 20:19:06 +09:00]] 版) <http://www.gyao.jp/>
>
[PRE(HTML invalid example code)[
<meta http-equiv="Content-script-Type" content="text/javascript; charset=Shift_jis" />
<meta http-equiv="Content-style-Type" content="text/css; charset=Shift_jis" />
]PRE]
[40] [CITE[Document Structure – SVG Tiny 1.2]] ([TIME[2008-12-20 02:31:29 +09:00]] 版) <http://www.w3.org/TR/2008/REC-SVGTiny12-20081222/struct.html#ContentScriptTypeAttribute>
[41] [CITE@en[Mozilla Labs » Zaphod » Blog Archive » Zaphod 1.0 Released]]
( ([TIME[2010-10-10 13:11:32 +09:00]] 版))
<http://mozillalabs.com/zaphod/2010/09/16/6/>
[42] [CITE@en[Web Applications 1.0 r8303 Move the event handler content attribute compiling logic to later in the pipeline, for better consistency with Firefox/Safari (and other browsers, though to a lesser extent).]]
( ([TIME[2013-11-21 06:09:00 +09:00]] 版))
<http://html5.org/tools/web-apps-tracker?from=8302&to=8303>
[43] [CITE@en[Web Applications 1.0 r8592 PARSER CHANGE: remove some attributes from the SVG attribute mapping]]
( ([TIME[2014-05-01 03:55:00 +09:00]] 版))
<http://html5.org/tools/web-apps-tracker?from=8591&to=8592>
[49] [CITE@en[Note how the SVG currently implemented in browsers is a mix of SVG 1.… · whatwg/html@969c45b]]
([TIME[2015-11-18 11:29:07 +09:00]] 版)
<https://github.com/whatwg/html/commit/969c45b2478d1d2d3be8564ec85dc316a53c8bcf>
[47] [CITE@en[Do not allow http-equiv values curated via wiki]]
([[domenic]]著, [TIME[2017-12-14 07:27:41 +09:00]])
<https://github.com/whatwg/html/commit/72d084b81fa94915518b9cf279afef87d835e88e>