XML Inclusions(XInclude)は、ひとつの XML 文書の中へ別の XML 文書(またはテキストファイル)を取り込み、複数の XML 文書を一つに統合する言語構文である。XInclude 自体も XML に準拠した埋め込み式のマークアップ言語である。
米国時間2004年12月20日に World Wide Web Consortium (W3C) から「XML Inclusions Version 1.0」が仕様としてリリースされ、W3C勧告となった。その後改定され、2006年11月15日に1.0 Second EditionがW3C勧告となっている。
XInclude は「xi」の名前空間接頭辞をもち、名前空間名は "http://www.w3.org/2001/XInclude" である。つまり、XInclude の要素 <xi:include> の先祖ノードで、予約属性 xmlns:xi を用いて以下のような名前空間宣言が必要となる。
<先祖ノード名 xmlns:xi="http://www.w3.org/2001/XInclude" >
XML Inclusions Version 1.0 では、2つの要素と6つの属性が定義されている。
<xi:include>
要素href
属性(省略可能)parse
属性(省略可能)xpointer
属性(省略可能)encoding
属性(省略可能)accept
属性(省略可能)accept-language
属性 (省略可能)<xi:fallback>
要素wikipedia.txt
として保存された (1) の文書を、(2) の XML 文書の中へ取り込む例。
(1) wikipedia.txt
<p>ウィキペディアはオープンコンテントの百科事典です。</p>
(2) XML 文書
<?xml version="1.0"?>
<root xmlns="..."
xmlns:xi="http://www.w3.org/2001/XInclude">
...
<body>
<p><xi:include href="wikipedia.txt" parse="text"/></p>
</body>
</root>
この XML 文書を処理すると、以下のような結果となる。
<?xml version="1.0"?>
<root xmlns="..."
xmlns:xi="http://www.w3.org/2001/XInclude">
...
<body>
<p><p>ウィキペディアはオープンコンテントの百科事典です。</p></p>
</body>
</root>
wikipedia.xml
として保存された (1) の文書を、(2) の XML 文書の中へ取り込む例。
(1) wikipedia.xml
<?xml version="1.0"?>
<p>ウィキペディアはオープンコンテントの百科事典です。</p>
(2)XML 文書
<?xml version="1.0"?>
<root xmlns="..."
xmlns:xi="http://www.w3.org/2001/XInclude">
...
<body>
<xi:include href="wikipedia.xml" parse="xml" />
</body>
</root>
この XML 文書を処理すると、以下のような結果となる。
<?xml version="1.0"?>
<root xmlns="..."
xmlns:xi="http://www.w3.org/2001/XInclude">
<head>...</head>
<body>
<p>ウィキペディアはオープンコンテントの百科事典です。</p>
</body>
</root>
XPointer と組み合わせて、別の XML 文書の一部を取り込むこともできる。wikipedia.xml
として保存された (1) の文書のテキスト部分のみを、(2) の XML 文書の中へ取り込む例。
(1) wikipedia.xml
<?xml version="1.0"?>
<p>ウィキペディアはオープンコンテントの百科事典です。</p>
(2) XML 文書
<?xml version="1.0"?>
<root xmlns="..."
xmlns:xi="http://www.w3.org/2001/XInclude">
...
<body>
<p><xi:include href="wikipedia.xml" xpointer="xpointer(//p/text())" parse="xml" /></p>
</body>
</root>
この XML 文書を処理すると、以下のような結果となる。
<?xml version="1.0"?>
<root xmlns="..."
xmlns:xi="http://www.w3.org/2001/XInclude">
...
<body>
<p>ウィキペディアはオープンコンテントの百科事典です。</p>
</body>
</root>
取り込んだ XML 文書にさらに xi:include 要素があれば、その xi:include 要素も再帰的に処理される。この処理は xpointer が解釈される前に実行される[2]。ただし href 属性が自分自身を差している場合は xi:include が処理される前に xpointer は解釈される[3]。
再帰処理の中で既に処理した xi:include 要素と同じ文書を指定し、なおかつ同じ xpointer を指定した xi:include 要素を処理しようとした場合、エラーとなる。
文書を取得する際、xml:base などで指定されたベース URI は考慮される。
取り込まれた文書のベース URI、言語(xml:lang で指定されるもの)は保存される。つまり取り込む文書と取り込まれた文書でベース URI や言語が違う場合は、xml:base 属性や xml:lang 属性が付加される。ただし、この動作はユーザによって抑制できるように実装してもよい。
一方、ID による参照は保存されない。ID は文書を取り込んだ後に解釈される。複数の参照先がある場合は、どれも参照しない[4]。
![]() | この節の加筆が望まれています。 |
XInclude は (X)HTML の<object> 要素や、show 属性として "embed" を指定した XLink とは異なる[5]。object 要素や XLink は、文中に埋め込んで表示すべきリソースを差し示すのみであり、その具体的な処理方法はアプリケーションに委ねられている。Firefox 3 等の既存の Web ブラウザでの実装や、HTML5 のドラフトで示されている処理方法では、object 要素は DOM ツリー上では置き換えられず、表示上置き換えられるのみである。一方 XInclude では XML infoset の一部を他の XML 文書またはテキストから作成した XML infoset で置き換えた新しい XML infoset を作成する具体的な処理モデルが定められている。取り込まれた文書は取り込まれた先の文書の一部として扱われ、元の文書中での位置などの情報は失われる。
XSLT は XML を変換するための汎用的な機構であり、2009年10月現在 Internet Explorer, Firefox, Opera, Safari, Google Chromeなどの主要なブラウザでサポートされている。document 関数を使うことで、XInclude に似た効果が得られる。
![]() | この節の加筆が望まれています。 |
2009年10月現在、主要なWeb ブラウザはXInclude をサポートしていない。