* [CODE(XML)[ID]] 型 (XML) [8] [[XHTML m12n]] の[[抽象モジュール]]定義における[[属性型]] [DFN[[CODE(XML)[ID]]]] は、 [[XML 1.0]] の定義によっています。 仕様書: - [[Web体系]] -- [CSECTION@en[4.5.6. XML ID semantics]] - [[XHTML m12n]] -- [CSECTION[4.3. Attribute Types]] - [xmlIDSemantics-32] [CSECTION@en[How should the problem of identifying ID semantics in XML languages be addressed in the absence of a DTD?]] [1] [[XML名前空間]]を使って [CODE(SGML)[ID]] 型属性を複数使えるか。例えば [[XHTML]] の要素に [CODE(XML)[[[RDF]]:[[ID]]]] 属性をつけることが出来るか。 [2] >>1 [[SGML]] でも [[XML]] でも、1つの要素に2つ以上の [CODE(SGML)[ID]] 属性は禁じている。よって出来ない。名前空間が違っても同じこと。 [3] [[XPath]] では、[[妥当]]でない文書も扱うわけですが、 そういう文書では同じ識別子を持った要素が複数あることもあります。 そういうときに、 [[文書順]]で2番目以降の要素は識別子を持たないこととして処理します。 [4] >>3、簡単なことのように思えますが、 [SAMP(XPath)[[VAR[path/to/element1]]/id()]] と [SAMP(XPath)[[VAR[path/to/element2]]/id()]] が同じ値を返しちゃいけないわけです。 だけど常識的に [SAMP(XPath)[[VAR[path/to/element1]]/@[VAR[id-attr]]]] と [SAMP(XPath)[[VAR[path/to/element2]]/@[VAR[id-attr]]]] は同じ値じゃないといけないでしょ? だから構造木を作ったときにでも重複をチェックして、 それを覚えとかないと。 もちろん木を操作して別の要素に識別子を与えたり、 最初の要素の識別子を削除したりしたら、 それに同期してどの属性が有効かも変更しないといけないんです。 - [6] >>4 みたいな面倒なことするよりは、 [CODE(XPathf)[[[id]]]] 関数とか識別子を使う時に木を走査する方が安上がりですね。 [9] >>3-6 元々 [[XPath]] のデータ・モデルや [[XML情報集合]]的には、 [[XML]] [[実体]]の構文解析・妥当性検証の時点で[[識別子]]と[[要素]]の対応の一覧表を作って、 あとから[[識別子]]が必要になったらその表を引くことを想定しているのだと思われ。 ([[名無しさん]] [sage]) [10] [CITE[How should the problem of identifying ID semantics in XML languages be addressed in the absence of a DTD?]] ([[名無しさん]] [sage]) [[#comment]] * ID 型 (HTML 4) [5] まあ [[HTML 4]] の [CODE(SGML)[ID]] 型といっても、 [[SGML]] の [CODE(SGML)[ID]] 型そのものなのでありますが・・・。 HTML 4 の [[SGML宣言]]の状況下では、 - [CODE(ABNF)[[DFN[ID]] := [[ALPHA]] / [[DIGIT]] / "-" / "_" / "." / ":"]] なのです。 参照。 大文字・小文字の区別はありません。 SGML の規則により小文字は大文字に変換されます。 [7] あ、1文字目は [CODE(ABNF)[ALPHA]] でないと。 [[噂のID問題]]も。 ([[名無しさん]]) [[#comment]] * メモ