<html xmlns="http://www.w3.org/1999/xhtml" a0:Name="SuikaWiki" xmlns:a0="urn:x-suika-fam-cx:markup:suikawiki:0:9:" a0:Version="0.9"><head></head><body><p><a0:anchor-end a0:anchor="1">[1]</a0:anchor-end> <a0:anchor>XSLT</a0:anchor> の関数 <code><var><a0:anchor>文字列</a0:anchor></var> <code class="XPathf">generate-id</code> (<var><a0:anchor>節集合</a0:anchor></var>?)</code>
は、<a0:anchor>節</a0:anchor>の固有識別子を生成します。
<a0:anchor-external a0:resParameter="http://www.w3.org/TR/xslt#function-generate-id" a0:resScheme="URI">http://www.w3.org/TR/xslt#function-generate-id</a0:anchor-external></p><p>対象となる節は、与えられた節集合中の<a0:anchor>文書順</a0:anchor>で最初のものです。
空節集合の時は得られる結果が空文字列になります。
引数省略時は<a0:anchor>文脈節</a0:anchor>になります。</p><p>識別子は <code class="ABNF"><a0:anchor>ALPHA</a0:anchor> *(ALPHA / <a0:anchor>DIGIT</a0:anchor>)</code>
でさえあれば、どんな方法で生成した文字列でも構いません。
ただし、<ul><li>ある一つの変換処理においては、
同じ節については同じ識別子を、違う節については違う識別子を常に生成しなければなりません。</li><li>原始文書中の <code class="XML"><a0:anchor>ID</a0:anchor></code> と別の識別子になることを保証する必要はありません。</li><li><code class="XPathf"><a0:anchor>document</a0:anchor></code> 関数で読んだ文書であっても、同じ文書 (同じ URI) であれば同じ節では同じ結果が得られます。</li><li>違う文書で違う識別子が得られる必要があるかは書いてありませんが、特に書いてないから違う節では違う識別子が必要でしょう。</li></ul></p></body></html>