blob: 4d867ee865811ee1b54c2fae85811ec88fe55151 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
|
---
title: Feed content access API
slug: orphaned/Feed_content_access_API
tags:
- Add-ons
- Extensions
original_slug: Feed_content_access_API
---
<p><a href="ja/Firefox_2">Firefox 2</a> と Thunderbird 2 は拡張製作者に RSS と Atom フィードへのアクセスを簡単にする一連のインターフェースを導入します。</p>
<h2 id=".E3.83.95.E3.82.A3.E3.83.BC.E3.83.89.E3.82.A4.E3.83.B3.E3.82.BF.E3.83.95.E3.82.A7.E3.83.BC.E3.82.B9" name=".E3.83.95.E3.82.A3.E3.83.BC.E3.83.89.E3.82.A4.E3.83.B3.E3.82.BF.E3.83.95.E3.82.A7.E3.83.BC.E3.82.B9">フィードインタフェース</h2>
<dl>
<dt>
<code><a href="ja/NsIFeed">nsIFeed</a></code></dt>
<dd>
RSS あるいは Atom フィードを表します。</dd>
<dt>
<code><a href="ja/NsIFeedContainer">nsIFeedContainer</a></code></dt>
<dd>
サブクラスされたフィード関連の様々なインタフェースのベースクラス。</dd>
<dt>
<code><a href="ja/NsIFeedElementBase">nsIFeedElementBase</a></code></dt>
<dd>
サブクラスされたフィード関連の他の様々なインタフェースのベースクラス。</dd>
<dt>
<code><a href="ja/NsIFeedEntry">nsIFeedEntry</a></code></dt>
<dd>
RSS あるいは Atom フィードの単一のエントリを表します。</dd>
<dt>
<code><a href="ja/NsIFeedGenerator">nsIFeedGenerator</a></code></dt>
<dd>
RSS あるいは Atom フィードを生成したソフトウェアを記述します。</dd>
<dt>
<code><a href="ja/NsIFeedPerson">nsIFeedPerson</a></code></dt>
<dd>
人を表します。人の名前とメールアドレス及びホームページアドレスを含んでいます。</dd>
<dt>
<code><a href="ja/NsIFeedProcessor">nsIFeedProcessor</a></code></dt>
<dd>
RSS と Atom フィードをパースします。</dd>
<dt>
<code><a href="ja/NsIFeedProgressListener">nsIFeedProgressListener</a></code></dt>
<dd>
パース処理中にメッセージを受け取るために RSS あるいは Atom フィードをパースしたいプログラムによって実装されます。</dd>
<dt>
<code><a href="ja/NsIFeedResult">nsIFeedResult</a></code></dt>
<dd>
フィードのパースの結果を表現します。</dd>
<dt>
<code><a href="ja/NsIFeedResultListener">nsIFeedResultListener</a></code></dt>
<dd>
パースが完了したときに通知を受け取るために RSS あるいは Atom フィードをパースしたいプログラムによって実装されます。</dd>
<dt>
<code><a href="ja/NsIFeedTextConstruct">nsIFeedTextConstruct</a></code></dt>
<dd>
フィードのテキストを表します: テキストをプレーンテキストあるいは HTML でフェッチするための関数を含んでいます。</dd>
<dt>
<code><a href="ja/NsIScriptableUnescapeHTML">nsIScriptableUnescapeHTML</a></code></dt>
<dd>
HTML 文字列をアンエスケープするためのユーティリティクラス。</dd>
</dl>
<h2 id=".E4.BE.8B:_Web_.E3.81.8B.E3.82.89.E3.83.95.E3.82.A3.E3.83.BC.E3.83.89.E3.82.92.E8.AA.AD.E3.82.80" name=".E4.BE.8B:_Web_.E3.81.8B.E3.82.89.E3.83.95.E3.82.A3.E3.83.BC.E3.83.89.E3.82.92.E8.AA.AD.E3.82.80">例: Web からフィードを読む</h2>
<p>フィードを読み込みパースすることは本当に簡単です。 フィードを読み込むために <code><a href="ja/XMLHttpRequest">XMLHttpRequest</a></code> を使い、次にフィードをパースするためにその文字列を <code><a href="ja/NsIFeedProcessor">nsIFeedProcessor</a></code> に渡します。</p>
<p>フィードを読み込み、パーサにそれを渡すことはこのようなコードを使って行うことができます:</p>
<pre> fetch: function(feedUrl)
{
var httpRequest = null;
function infoReceived() {
var data = httpRequest.responseText;
var ioService = Components.classes['@mozilla.org/network/io-service;1']
.getService(Components.interfaces.nsIIOService);
var uri = ioService.newURI(feedUrl, null, null);
if (data.length) {
var parser = Components.classes["@mozilla.org/feed-processor;1"]
.createInstance(Components.interfaces.nsIFeedProcessor);
var listener = new FeedTestResultListener();
try {
parser.listener = listener;
parser.parseFromString(data, uri);
}
catch(e) {
alert("フィードのパースでエラーが発生しました。");
}
}
}
httpRequest = new XMLHttpRequest();
httpRequest.open("GET", feedUrl, true);
try {
httpRequest.onload = infoReceived;
httpRequest.send(null);
}
catch(e) {
alert(e);
}
}
</pre>
<p><code><a href="ja/NsIFeedProcessor">nsIFeedProcessor</a></code> インタフェースであなたはいくつかの可能なソースからフィードデータをパースできます; この場合、ドキュメントを文字列に読み込み、次に <code>parseFromString()</code> メソッドを使ってパースしています。しかし <code>parseFromStream()</code> を使ってファイルから、<code>parseAsync()</code> を使って直接 URL からパースすることもできます。</p>
<p>パースされたフィードの実際の処理は <code>FeedTestResultListener</code> オブジェクトの <code>handleResult()</code> を使って行われます。そのコードはこのようになります:</p>
<pre> FeedTestResultListener.prototype = {
handleResult: function(result) {
var feed = result.doc;
feed.QueryInterface(Components.interfaces.nsIFeed);
// 新しいウィンドウを開く
var win = window.open("", "FeedTest_Window");
var doc = win.document.wrappedJSObject;
doc.open();
// HTML ヘッダとページタイトルを書き込む
doc.write("<html><head><title>Feed: " + feed.title.text + "</title></head><body>");
doc.write("<h1>" + feed.title.text + "</h1><p>");
var itemArray = feed.items;
var numItems = itemArray.length;
// 記事の情報を書き込む
if (!numItems) {
doc.write("<i>便りのないのは良い便り!</i>");
}
else {
var i;
var theEntry;
var theUrl;
var info;
for (i=0; i<numItems; i++) {
theEntry = itemArray.queryElementAt(i, Components.interfaces.nsIFeedEntry);
if (theEntry) {
theUrl =
doc.write('<b><a href="' + theEntry.link.resolve("") + '">' + theEntry.title.text + '</a></b><br>');
if (theEntry.summary) {
info = theEntry.summary.text + "</p><hr><p>";
}
else {
info = theEntry.content.text + "</p><hr><p>";
}
doc.write("<blockquote>" + info);
doc.write("</blockquote><p>");
}
}
}
// ドキュメントを閉じる; 完了!
doc.write("</body></html>");
doc.close();
}
}
</pre>
<p><code>handleResult()</code> 関数はフィードを表現している <code><a href="ja/NsIFeedResult">nsIFeedResult</a></code> を引数として受け取ります。<code>doc</code> プロパティは全てのフィードデータを含んだ <code><a href="ja/NsIFeed">nsIFeed</a></code> です。</p>
<p>フィードのタイトルを得るためには、<code>feed.title</code> プロパティを見てください。タイトルは様々なフォーマットのテキストを表す <code><a href="ja/NsIFeedTextConstruct">nsIFeedTextConstruct</a></code> です。HTML エンコードされたテキストとしてフィードのタイトルを得るために、その <code>text</code> プロパティを取得します。代りに <code>plainText()</code> メソッドを使うことで、プレーンテキストに変換されたタイトルのコピーを得ることができます。</p>
<p>次に、<code>feed.items</code> <code><a href="ja/NsIArray">nsIArray</a></code> を見ることでフィードのアイテムの配列をスキャンしています。この配列はそれぞれのフィードアイテムを表す <code><a href="ja/NsIFeedEntry">nsIFeedEntry</a></code> オブジェクトを含んでいます。</p>
<p>それぞれのアイテムの title と link、summary そして content プロパティをみることでドキュメントのコンテンツを作り上げています。 link の完全なURL は link の <code>resolve()</code> メソッドを使うことで得ることができます。</p>
<p>フィードのフェッチを初期化するには、単に <code>fetch(
<i>
url</i>
)</code> と呼びます。これはフィードコンテンツを含む新しいウィンドウを開ききます。それはそれぞれのアイテムのタイトル(記事自体へのクリック可能なリンクを持っています)を持っています。</p>
<p>フィードアクセスインタフェースそれぞれの詳細は、個別のリファレンスページを見てください。</p>
|