[2] HTML の isindex
要素は、元々はその文書 (によって代表される資源)
が検索可能であることを表していました。
その後フォームが開発され、使われなくなりました。
action | %URI | 提出先 | |||
class | (なし) | 級 | [HTML 4] %coreattrs | ||
dir | 書字方向 | [HTML 4] %i18n | |||
href | %URI | 提出先 | |||
id | ID | (なし) | 固有識別子 | [HTML 4] %coreattrs | |
lang | %LanguageCode | (継承) | 自然言語 | [HTML 4] %i18n | |
xml:lang | %LanguageCode | (継承) | 自然言語 | W3C 勧告 | [XHTML 1] |
prompt | %Text | [HTML 4] 非推奨 | |||
style | %StyleSheet | (なし) | スタイル指定 | [HTML 4] %coreattrs | |
title | %Text | (なし) | 注釈的題 | [HTML 4] %coreattrs | |
type | khtml_isindex | (なし) | 非標準 | WebKit |
[38] isindex
要素は完全に廃止され、
Webブラウザーも未知の HTML要素と扱うようになりました。
[106] isindex
要素は歴史的にいろいろな形で実装されてきましたが、
現在の HTML Standard では form
要素とその子孫という形に構文解析器の時点で展開される
「マクロ」として定義されています。各 Webブラウザーの現行世代の構文解析器 (いわゆる HTML5構文解析器)
もすべてそのように実装しています。
input
要素の name
「isindex
」[39] かつてはコントロール名 isindex
は特別扱いされていました。
現在は特殊な動作のない普通の値となっています。
[8] メッセージつきの例 HTML 4 17.8
<ISINDEX prompt="Enter your search phrase: ">
input
を使って書き換えた例 HTML 4 17.8、改
<FORM action="..." method="get"> <P><LABEL>Enter your search phrase: <INPUT type="text"></LABEL></P> </FORM>
但し、フォームと索引では提出方法が異なるので、 この2つの例は交換可能ではありません。
<ISINDEX iPROMPT="Enter WAIS query:" HREF="wais://net.bio.net/biologists-addresses">
[41] Elements/isindex - HTML Wiki, , https://web.archive.org/web/20230216093940/https://www.w3.org/html/wiki/Elements/isindex
[6] 本来この要素は索引があって検索可能なことを表すだけで、 検索フォームは UA の機能に過ぎなかった (本文領域には表示せず、メニューから検索機能を呼出せるだけの UA もあった)]] のに、 いつの間にか文章の適当なところに配置できる簡易フォーム機能となってしまいました。 フォーム提出先 URI まで指定できるようになっています (HTML 4 にはその機能は入りませんでしたが)。
HTML 4 に至っては、
This element creates a single-line text input control. HTML 4 17.8
などと定義しています。
[7] しかも、 head
要素が創設された時にそちらに収納されるはずのものであったにもかかわらず、
いつの間にか本文のどこにあっても良いことになっています。
ここまでして高機能化するほど使い道があるものではありませんし、
form
が使いづらいというわけでもないのですが、
どうしてこうも拡張されてしまったのでしょうと思わずにはいられません。
[44] Notes on informal HTML-IG meeting 25 July 94 ( 版) http://www.w3.org/MarkUp/HTML-WG/940725-minutes.html
ISINDEX should not be allowed in the body of messages. (This has always been a bug encouraged by Mosaic's handling of if, but it should be done with a small form, and it is messy to allow it in two roles.)
[10]
HTML 4 DTD の注釈 (参考)
には single line prompt
とあります。
[9] isindex
の意味がよく規定されているのは基底URI
が HTTP である場合のみです。また、入力する文字列は Latin-1
に制限されます。 HTML 4 17.8
[1] WebTV では「属性なし」で、次のような例が載っています。
<ISINDEX "http://www.webtv.net/search">
(出典: isindex
http://web.archive.org/web/20000601075627/developer.webtv.net/authoring/html/isindex.html#1082776)
こんなのは SGML ではないと思うんですがねぇ。
[122] ncsa-mosaic/CHANGES at master · alandipert/ncsa-mosaic ( ( 版)) https://github.com/alandipert/ncsa-mosaic/blob/master/CHANGES#L700
[123] ncsa-mosaic/CHANGES at master · alandipert/ncsa-mosaic ( ( 版)) https://github.com/alandipert/ncsa-mosaic/blob/master/CHANGES#L736
[124] ncsa-mosaic/libhtmlw/HTMLformat.c at master · alandipert/ncsa-mosaic ( ( 版)) https://github.com/alandipert/ncsa-mosaic/blob/master/libhtmlw/HTMLformat.c#L4710
[125] これらによると Mosaic では form
が実装された時点で
isindex
も form
に展開される形になっていたようです。
更にコンパイル時オプションで提出ボタンつきのものも実装されていたようです (なぜそれが標準にならなかったのかは不明です)。
[146] WWW-Talk 1992: <ISINDEX> and anchor types ( ( 版)) http://1997.webhistory.org/www.lists/www-talk.1992/0080.html
[147] indexes as links rather than documents ( ( 版)) http://lists.w3.org/Archives/Public/www-talk/1992NovDec/0031.html
[148] ISINDEX on documents ( ( 版)) http://lists.w3.org/Archives/Public/www-talk/1992NovDec/0042.html
[149] Re: ISINDEX on documents ( ( 版)) http://lists.w3.org/Archives/Public/www-talk/1992NovDec/0044.html
[21] WWW-Talk Oct-Dec 1993: Mosaic2.0 and ISINDEX ( 版) http://1997.webhistory.org/www.lists/www-talk.1993q4/0493.html
[22] libwww-perl/gopher.pm at master · libwww-perl/libwww-perl ( 版) https://github.com/libwww-perl/libwww-perl/blob/master/lib/LWP/Protocol/gopher.pm#L89
[12] isindex
要素型は元々の意味からすると
head
内でのみ認められるべきでしたし、
何個あっても意味が変わらないので高々1個だけ認められるべきでした。
しかし、 isindex
要素の場所に入力欄を設けるという実装が行われるようになり、
文書のあらゆる場所に何個でも置けるように拡張
されてしまいました。
[13] HTML 4 ではこの要素型を %block
に分類しています。従って、 body
内の行内要素しか認められない場所以外ほとんどどこにでも書けます。
また、 DTD 内の引数実体 %head.content
で高々1回記述できると規定しています。つまり、 head
の子供としてどこにでも1回だけ指定できます。
[11] XHTML 1.0 互換性指針は、 head
内に複数の isindex
を入れるのは互換性のため好ましくないとしています
XHTML 1.0 C.6。
XHTML 1.0 の DTD をよく見ると isindex
が %block;
に含まれるのはそのままですが、
head
については %head.misc;
に移動していることがわかります。 XML
の内容模型の記述能力の限界により、
簡単のため定義の仕方が変わったようです。
これにより、 isindex
は head
内であっても任意の回数使用できるようになりました。
互換性指針が言っているのはこの変更のことのようです。
[19] >>11 この変更についてBjoern Hoehrmannが問い質していますが、 Steven Pembertonは >>11 のような説明をしています。 それに対してBjoern Hoehrmannは、DTDの変更は他にもあるのにどうしてこれだけ取り上げるのだとたずねていますが、 返答はありません。
[14]
Firefox 1.5では、isindex
タグおよびその中の属性指定がそのままDOM上の要素節点および属性節点として反映されます。表示上は
<hr> prompt text<input type="text"> <hr>
のようになります (XBLではないようです)。
prompt textはprompt
属性値か、
なければ利用者界面と同じ言語の文章になります。
日本語の場合
これは検索可能なインデックスです。検索キーワードを入力してください:
になります。
isindex
にCSSを適用することは可能ですが、
hr
のようなものやinput
のようなものには適用できないみたいです。
(名無しさん)
[15]
innerHTML
にはisindex
の開始タグ (とあれば、属性指定) だけが現れます。
(名無しさん)
[16]
Opera 8.5およびOpera 9 TP1では、isindex
開始タグはDOM木においてisindex
要素節点になり、その子供として
が作られます。
isindex
にはCSSが適用され、
その子供も通常の方法でCSSによってレンダリングされるようです。
innerHTML
にはisindex
の開始タグ (とあれば、属性指定)
の後に、内容を直列化したものが現れます。
(終了タグは現れません。)
(名無しさん)
[17]
WinIE 6では、isindex
開始タグはDOMグラフにおいてform
要素節点と、
その子供の節点列:
となります。属性は、
action
属性があれば、
DOMではform
要素に指定されます。name
属性やtype
属性があっても、DOMには現れません。prompt
属性はテキスト節点として現れ、属性としてはDOMに現れません。input
要素節点に付されます。
それがinput
要素で有効な属性であるなら、その効果が現れます。CSSによるレンダリング指定はDOM上の要素構造に対して適用され、
isindex
要素への指定は適用されません。
innerHTML
はDOM上の構造を直列化したものとなります。
[96] createElement
で作った isindex
要素を HTML文書に挿入した場合、
isindex
要素として機能します<input type=text>
のようにレンダリングされます (動きは未検証)どのブラウザでも DOM 上は isindex
要素のままです。
[98] XHTML に isindex
要素が含まれる場合、
DOM 上は
という感じです。
<isindex><hr/>This is a searchable index<br/><input xmlns="text" xml:lang="20"/><hr/></isindex>のように属性がちょっとおかしいです。
isindex
要素 type
属性[92]
WebKit は、 isindex
開始タグが HTML文書中に現れると、
代わりに div
要素などを DOM
に挿入しますが、その一部として、入力欄の部分には isindex
要素が挿入され、その type
属性は
khtml_isindex
となります。
[93] (X)HTML5 Tracking ( 版) http://html5.org/tools/web-apps-tracker?from=4023&to=4024
[94] Manual pages ( 版) http://costard.lbl.gov/cgi-bin/man/man2html
[95] IRC logs: freenode / #whatwg / 20100311 ( 版) http://krijnhoetmer.nl/irc-logs/whatwg/20100311#l-326
[100] HTML5 Revision Tracker ( 版) http://html5.org/tools/web-apps-tracker?from=4935&to=4936
[103] Intent to remove <isindex>. - Google グループ ( ( 版)) https://groups.google.com/a/chromium.org/forum/#!topic/blink-dev/14q_I06gwg8
Google index files say <isindex> is used 0.000011% of pages as of December 2, 2013.
[136] [whatwg] isindex as a parser macro ( ( 版)) http://lists.whatwg.org/pipermail/whatwg-whatwg.org/2010-February/067379.html
[137] [whatwg] <isindex prompt> ( ( 版)) http://lists.whatwg.org/htdig.cgi/whatwg-whatwg.org/2007-February/221248.html
[138] [whatwg] Form-associated elements and the parser ( ( 版)) http://lists.whatwg.org/pipermail/whatwg-whatwg.org/2013-December/041719.html
[139] Web Applications 1.0 r3236 Remove the <p> from 'isindex' parsing. ( ( 版)) http://html5.org/r/3236
[112] Blink では >>113 の500行目付近で構文解析が実装されています。 prompt
の値は SearchableIndexIntroduction
を参照しています。その実際の値は >>114 の各ロケールの XML
ファイルに "8141602879876242471"
という値で含まれています。
[115] Gecko では >>116 や >>117 の IsIndexPromptWithSpace
が prompt
の値です。各ロケールのファイルが各ロケールのリポジトリの >>117 と同じディレクトリに入っています。
[120] >>119 に Gecko と Chromium の各言語のデータを JSON 化したものがあります。
[118] HTML Standard は isindex
の前後どちらにも文字列を挿入することを認めていますが、
Blink も Gecko も前にしか挿入しないようです。 (各ロケールのデータがそうなっているだけでなく、
構文解析器に後ろ側に文字列を挿入するコードがありません。
[144] HTML5構文解析器では type
属性は無視されずに
input
要素に設定されます。ですから
input
要素の任意のフォーム制御子を使うことができます。
[121] IRC logs: freenode / #whatwg / 20140311 ( ( 版)) http://krijnhoetmer.nl/irc-logs/whatwg/20140311#l-429
[126] Issue 98743002: Count usage of the obsolete 'isindex' element. - Code Review ( ( 版)) https://codereview.chromium.org/98743002
[127] MFSA 2010-76: window.open と <isindex> 要素によるクローム特権昇格 ( ( 版)) http://www.mozilla-japan.org/security/announce/2010/mfsa2010-76.html
[128] Issue 96653004: Remove support for the obsolete <isindex> tag. - Code Review ( ( 版)) https://codereview.chromium.org/96653004/
[129] Issue 182843002: Drop isindex from HTMLTagNames. - Code Review ( ( 版)) https://codereview.chromium.org/182843002
[130] Issue 433 - chromium - WebKit should support ISINDEX as it is in the HTML 5 RFC - An open-source project to help move the web forward. - Google Project Hosting ( ( 版)) https://code.google.com/p/chromium/issues/detail?id=433
[131] Bug 7139 – Drop support for <isindex> ( ( 版)) https://bugs.webkit.org/show_bug.cgi?id=7139
[132] Bug 4574 – HTML parser does not put attributes on the <isindex> element ( ( 版)) https://bugs.webkit.org/show_bug.cgi?id=4574
[133] Bug 4828 – <form> element is created for <isindex> outside <form>; that's not correct ( ( 版)) https://bugs.webkit.org/show_bug.cgi?id=4828
[134] Bug 18415 – No DOM element created for <isindex> with no other tags in the document ( ( 版)) https://bugs.webkit.org/show_bug.cgi?id=18415
[135] HTMLIsIndexElement - Web API インターフェイス | MDN ( ( 版)) https://developer.mozilla.org/ja/docs/Web/API/HTMLIsIndexElement
[140] 609437 – (CVE-2010-3771) <isindex> doesn't CheckLoadURI ( ( 版)) https://bugzilla.mozilla.org/show_bug.cgi?id=609437
[141] 3326 – ISINDEX element ignored ( ( 版)) https://bugzilla.mozilla.org/show_bug.cgi?id=3326
[142] 666665 – Remove isindex content code ( ( 版)) https://bugzilla.mozilla.org/show_bug.cgi?id=666665
[143] 611352 – Create a HTMLElement when createElement('isindex') is called and the html5 parser is enabled ( ( 版)) https://bugzilla.mozilla.org/show_bug.cgi?id=611352
[145] Bug 26689 – Drop isindex? ( ( 版)) https://www.w3.org/Bugs/Public/show_bug.cgi?id=26689
[150] IRC logs: freenode / #whatwg / 20140901 ( ( 版)) http://krijnhoetmer.nl/irc-logs/whatwg/20140901#l-339
[24] Remove <isindex> and <input name=isindex> · whatwg/html@5c44abc ( 版) https://github.com/whatwg/html/commit/5c44abc734eb483f9a7ec79da5844d2fe63d9c3b
[25] 1266495 – Consider removing <isindex> from the parser and form submission ( 版) https://bugzilla.mozilla.org/show_bug.cgi?id=1266495
[26] 1266495 – Consider removing <isindex> from the parser and form submission ( 版) https://bugzilla.mozilla.org/show_bug.cgi?id=1266495
[27] Bug 7139 – Drop support for <isindex> ( 版) https://bugs.webkit.org/show_bug.cgi?id=7139
[28] Bug 4574 – HTML parser does not put attributes on the <isindex> element ( 版) https://bugs.webkit.org/show_bug.cgi?id=4574
[29] Bug 4828 – <form> element is created for <isindex> outside <form>; that's not correct ( 版) https://bugs.webkit.org/show_bug.cgi?id=4828
[30] Bug 18415 – No DOM element created for <isindex> with no other tags in the document ( 版) https://bugs.webkit.org/show_bug.cgi?id=18415
[31] Remove isindex handling from application/x-www-form-urlencoded · whatwg/url@c85fb5d ( 版) https://github.com/whatwg/url/commit/c85fb5d527f822e089aecc9207f077c6b886aed5
[35] Make <input name=isindex> non-conforming (sideshowbarker著, ) https://github.com/whatwg/html/commit/1bbba21f381ef95f826986b7d17992bd8f82573b
[36] 1266495 - Consider removing <isindex> from the parser and form submission [tor 18914] () https://bugzilla.mozilla.org/show_bug.cgi?id=1266495
[37] <isindex> support has been dropped | Firefox Site Compatibility () https://www.fxsitecompat.com/en-CA/docs/2017/isindex-support-has-been-dropped/
createElement
や XML でisindex
要素を作っても、isindex
としての機能は持ちません。