クエリを入力できるテスト ページを提供する検索サーバーがあり、結果が XML で返されます。よりユーザーフレンドリーな方法で結果を確認できるようにしたいので、XSLT をいじり始めました。今では単純なスタイルシートを作成して、何とか肥大化した XML をデータの一部だけを示す単純なテーブルに変換しています。これは、ローカルで行う場合、つまり、XSL 宣言を XML に追加してから、Firefox などのブラウザーで XML を開く場合に問題なく機能します。
私がやりたいことは、そのテスト ページを介してサーバーから結果を取得するとすぐに、この変換をブラウザーにライブで適用することです。少し調べたところ、javascript でこれを行うことが可能であることがわかりました。
次に、JavaScript をページに動的に挿入できる Greasemonkey ユーザースクリプトについて考えました。テスト ページから XML の結果を取得するときに起動するスクリプトが必要です。しかし、Greasemonkey が XML ファイルでのスクリプトの実行を許可していないように見えるため (少なくとも Firefox では)、私はそこで立ち往生しています。
ごく少数の例を見つけて、それらをインスピレーションとして使用しようとしましたが、機能させることができませんでした. (たとえば、これは 1 つです。)
取得している XML の簡単な例を次に示します。
<?xml version="1.0" encoding="utf-8"?>
<Results>
<Result>
<Listings total="2">
<Res>
<Result index="0">
<id>123456</id>
<name>My Business</name>
<category>Restaurants</category>
<phone>9872365</phone>
</Result>
</Res>
<Res>
<Result index="1">
<id>876553</id>
<name>Some Other Business</name>
<category>Restaurants</category>
<phone>9834756</phone>
</Result>
</Res>
</Listings>
</Result>
</Results>
これがGreasemonkeyにロードしているスクリプトです-何も起こっていません:
// ==UserScript==
// @name test xml renderer
// @namespace http://sample.com
// @description stylesheet for xml results
// @include *
// ==/UserScript==
(function () {
var xsl_str = '<?xml version="1.0" encoding="utf-8"?>\n\
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">\n\
<xsl:output method="html"/>\n\
<xsl:template match="/">\n\
<html>\n\
<head></head>\n\
<body>\n\
<table id="results" border="1" cellspacing="0" cellpadding="0">\n\
<thead>\n\
<tr>\n\
<th class="name">id</th>\n\
<th class="name">category ID</th>\n\
<th class="name">name</th>\n\
<th class="name">phone</th>\n\
</tr>\n\
</thead>\n\
<tbody>\n\
<xsl:for-each select="Results/Result/Listings/Res">\n\
<tr>\n\
<td class="small" width="120">\n\
<xsl:value-of select="Result/id"/>\n\
</td>\n\
<td class="small" width="120">\n\
<xsl:value-of select="Result/category"/>\n\
</td>\n\
<td class="small" width="120">\n\
<xsl:value-of select="Result/name"/>\n\
</td>\n\
<td class="small" width="120">\n\
<xsl:value-of select="Result/phone"/>\n\
</td>\n\
</tr>\n\
</xsl:for-each>\n\
</tbody>\n\
</table>\n\
</body>\n\
</html>\n\
</xsl:template>\n\
</xsl:stylesheet>\n\
';
var processor = new XSLTProcessor();
var dataXSL = new DOMParser().parseFromString(xsl_str, "text/xml");
processor.importStylesheet(dataXSL);
dataXML = document;
var ownerDocument = document.implementation.createDocument("", "", null);
var newFragment = processor.transformToFragment(dataXML, ownerDocument);
dataXML.documentElement.replaceChild(newFragment, dataXML.documentElement.firstChild);
})();
Greasemonkey でこのスクリプトを有効にすると、すべてのページが XSL テンプレートの上記の HTML に正常に置き換えられます。ただし、ローカル XML ファイルまたはサーバーからの XML には適用されないようです (Greasemonkey をローカル ファイルで動作させるにはabout:config
、Firefoxで設定を変更する必要があることを知っていますextensions.greasemonkey.fileIsGreaseable
)。
私は JavaScript の経験がないので、非常に基本的な間違いを犯している可能性が高いです。場合によっては、すべてのヘルプに本当に感謝しています。