XSLT - クライアント側

ブラウザがXSLTをサポートしている場合、ブラウザ内でドキュメントをXHTMLに変換することができます。

JavaScript解決策

前の章で、XSLTを使用してXMLドキュメントをXHTMLに変換する方法について説明しました。この作業を完了するために、以下の手順を踏みました:XMLファイルにXSLスタイルシートを追加し、ブラウザで変換を行いました。

この方法は効果が良いですが、XMLファイルにスタイルシートの参照を含めることは常に満足のいくものではありません(例えば、XSLTを認識できないブラウザではこの方法が機能しません)。

より一般的な方法として、JavaScriptを使用して変換を完了することができます。

JavaScriptを使用して、以下のことができます:

  • ブラウザ確認テストを実行します
  • ブラウザとユーザーのニーズに応じて異なるスタイルシートを使用してください

これが XSLT の魅力です!XSLT の設計目的の1つは、1つのフォーマットから別のフォーマットへの変換を可能にすることであり、また異なる種類のブラウザと異なるユーザーのニーズをサポートすることです。

ブラウザの XSLT 変換は、将来のブラウザが実行する主要なタスクの1つになるでしょう。また、特定のブラウザ市場におけるその成長(点字、ネットワークプリンター、聴覚デバイスなど)を目にするでしょう。

XML ファイルと XSL ファイル

前の章で示した XML 文書を確認してください:

<?xml version="1.0" encoding="ISO-8859-1"?>
<catalog>
  <cd>
    <title>Empire Burlesque</title>
    <artist>Bob Dylan</artist>
    <country>USA</country>
    <company>Columbia</company>
    <price>10.90</price>
    <year>1985</year>
  </cd>
。
。
。
</catalog>

この XML ファイルを確認してください

および付随の XSL スタイルシート:

<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
  <html>
  <body>
    <h2>My CD Collection</h2> 
    <table border="1">
      <tr bgcolor="#9acd32">
        <th align="left">Title</th> 
        <th align="left">Artist</th> 
      </tr>
      <xsl:for-each select="catalog/cd">
      <tr>
        <td><xsl:value-of select="title" /></td>
        <td><xsl:value-of select="artist" /></td>
      </tr>
      </xsl:for-each>
  </table>
  </body>
  </html>
</xsl:template>
</xsl:stylesheet>

このXSLファイルを確認する

このXMLファイルにはXSLファイルへの参照が含まれていませんのでご注意ください。

重要な事項:この文は、XMLファイルが複数の異なるXSLスタイルシートを使用して変換できることを意味します。

ブラウザでXMLをXHTMLに変換する

これはクライアント側でXMLファイルをXHTMLに変換するためのソースコードです:

<html>
<body>
<script type="text/javascript">
// Load XML 
var xml = new ActiveXObject("Microsoft.XMLDOM")
xml.async = false
xml.load("cdcatalog.xml")
// Load XSL
var xsl = new ActiveXObject("Microsoft.XMLDOM")
xsl.async = false
xsl.load("cdcatalog.xsl")
// Transform
document.write(xml.transformNode(xsl))
</script>
</body>
</html>

ヒント:JavaScriptを書く方法がわからない場合は、私たちの「JavaScriptチュートリアル》。

第一段コードはマイクロソフトのXMLパーサーのインスタンスを作成し、XMLファイルをメモリに読み込みます。第二段コードはパーサーの別のインスタンスを作成し、そのXSLファイルをメモリに読み込みます。最後の行コードはXSLドキュメントを使用してXMLドキュメントを変換し、結果をブラウザでXHTMLとして表示します。タスクが完了しました!

IE でどう動作するかを見てください