blob: f22691ca88669205f20b613b3acac1741892c92d (
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
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
|
---
title: Firefox 10 for developers
slug: Mozilla/Firefox/Releases/10
tags:
- Firefox
- Firefox 10
- Gecko 10
translation_of: Mozilla/Firefox/Releases/10
---
<div>{{ draft }}</div>
<p>Gecko 10.0 を搭載した Firefox 10 は米国時間 2012 年 1 月 31 日にリリースされました。このページでは、開発者に影響する Firefox 10 の変更点をまとめています。</p>
<div class="note"><strong>重要: </strong>Firefox 10 は、2 桁の数値で表記される最初のリリースです。これにより、一部の UserAgent 検出スクリプトで問題が発生するおそれがあります。そのようなスクリプトや、ページに埋め込まれているサードパーティのソフトウェア (ライブラリなど) で UserAgent 検出を行っているものの確認を行うようにしてください。この点に関する詳細情報は、hack.mozilla.org の記事 <a class="external" href="http://hacks.mozilla.org/2012/01/firefox-goes-2-digit-time-to-check-your-ua-sniffing-scripts/" title="http://hacks.mozilla.org/2012/01/firefox-goes-2-digit-time-to-check-your-ua-sniffing-scripts/">Firefox goes 2-digit article on </a> をご覧ください。</div>
<h2 id="Web_開発者向けの変更点一覧">Web 開発者向けの変更点一覧</h2>
<h3 id="HTML">HTML</h3>
<ul>
<li>方向が異なるテキストの部分を分離することを可能にする、HTML5 の {{ HTMLElement("bdi") }} (bi-directional isolation) 要素が実装されました。これは、既知の方向のテキスト内に未知の方向のテキスト (例えばデータベースから取り出したテキストで、方向が異なる可能性がある) を表示する場合に特に有用です。</li>
<li>{{ htmlattrxref("href", "a") }} 属性に、ページ先頭へのリンクを作成するための断片 "top" を指定可能になりました。これは過去に動作していてその後一時的に削除されていましたが、HTML5 仕様書との互換性のため再び動作するようになりました。例: <code><a href="#top">Return to top of page</a></code>.</li>
</ul>
<h3 id="JavaScript">JavaScript</h3>
<ul>
<li><code><a href="/ja/docs/JavaScript/Reference/Global_Objects/WeakMap" title="https://developer.mozilla.org/ja/docs/JavaScript/Reference/Global_Objects/WeakMap">WeakMap</a>.set()</code> メソッドの戻り値はそれ自身から <em><code>undefined</code></em> に替わりました。</li>
<li>Firefox 7 以降で正規表現のハンドリングに関する不具合がありましたが、修正されました。詳しくは {{ bug("683838") }} をご覧ください。</li>
<li><a href="/ja/docs/JavaScript/Reference/Functions_and_function_scope/Strict_mode" title="Strict mode">ECMAScript 5 strict mode</a> (すなわち、<code>"use strict;"</code> 以降) では、<a href="/ja/docs/E4X" title="E4X">E4X</a> の構文を使用できなくなりました。</li>
</ul>
<h3 id="DOM">DOM</h3>
<h4 id="DOM3_Events">DOM3 Events</h4>
<ul>
<li>DOM イベントの <a href="/ja/docs/DOM/event.stopImmediatePropagation" title="event.stopImmediatePropagation"><code>event.stopImmediatePropagation</code></a> メソッドが実装されました。</li>
<li>マウスイベントの <code>mouseenter</code> および <code>mouseleave</code> が実装されました。</li>
</ul>
<h4 id="DOM4">DOM4</h4>
<ul>
<li>DOM4 仕様書で非推奨とされたため、{{ domxref("document.xmlVersion") }} 属性 (読み取りのみ可能で、設定は不可) が削除されました。{{ domxref("document.xmlVersion") }} の記事では、このプロパティを使用せずに ドキュメントが HTML か XML かを判断する方法を提案しています。</li>
<li>DOM4 仕様書で非推奨とされたため、{{ domxref("document.xmlStandalone") }} 属性が削除されました。</li>
<li>DOM4 仕様書で非推奨とされたため、{{ domxref("document.xmlEncoding") }} 属性が削除されました。</li>
<li>DOM4 仕様書で非推奨とされたため、{{ domxref("text.isElementContentWhiteSpace") }} 属性が削除されました。</li>
<li>DOM4 仕様書で非推奨とされたため、{{ domxref("text.replaceWholeText") }} メソッドが削除されました。</li>
<li>DOM4 仕様書で非推奨とされたため、{{ domxref("node.isSameNode") }} メソッドが削除されました。<code><em>node1</em>.isSameNode(<em>node2</em>)</code> に代わり、<code>===</code> 演算子を使用できます。例: <code><em>node1 </em>===</code><code><em> node2</em></code></li>
</ul>
<h4 id="Page_Visibility_API">Page Visibility API</h4>
<ul>
<li><a href="/ja/docs/DOM/Using_the_Page_Visibility_API" title="Using the Page Visibility API">Page Visibility API</a> が実装されました (接頭辞が付加されています): <code>document.mozHidden</code>、<code>document.mozVisibilityState</code> が利用可能であり、また状態が変更されると <code>mozvisibilitychanged</code> イベントが送信されます。</li>
</ul>
<h4 id="Full_Screen_API">Full Screen API</h4>
<ul>
<li>{{ domxref("document.mozFullScreenEnabled") }} のサポートが追加されました。</li>
<li>{{ cssxref(":-moz-full-screen-ancestor") }} プロパティが追加されました。これはフルスクリーンモードになっている要素の祖先要素に対してマッチします。</li>
</ul>
<h4 id="Battery_API">Battery API</h4>
<ul>
<li>{{ domxref("window.navigator.mozBattery") }} の実験的なサポートが追加されました (設定 <code>dom.battery.enabled</code> を <code>true</code> にすることで有効になります。また、Firefox 11 からはデフォルトで有効になる予定です)。</li>
</ul>
<h4 id="Canvas">Canvas</h4>
<ul>
<li><a href="/ja/docs/DOM/CanvasRenderingContext2D#createPattern%28%29" title="DOM/CanvasRenderingContext2D#createPattern%28%29"><code>createPattern()</code></a> メソッドは、サイズが 0 の canvas が指定された場合に例外が発生するようになりました。</li>
<li>仕様書に準拠するため、<a href="/ja/docs/DOM/CanvasRenderingContext2D#putImageData%28%29" title="DOM/CanvasRenderingContext2D#putImageData%28%29"><code>putImageData()</code></a> の数値引数のいずれかに有限値でない値を与えたときに例外が発生するのではなく、値を無視するようになりました。</li>
</ul>
<h4 id="WebGL">WebGL</h4>
<ul>
<li>Firefox 10 で、<a class="external" href="http://www.khronos.org/registry/webgl/extensions/OES_standard_derivatives/" title="http://www.khronos.org/registry/webgl/extensions/OES_standard_derivatives/"><code>OES_standard_derivatives</code></a> 拡張がサポートされました。</li>
<li>完全な開発環境上で、最低限のサポートにとどまるデバイスとの WebGL コードの互換性を確認するために役立つ <a href="/ja/docs/WebGL#WebGL_debugging_and_testing" title="WebGL#WebGL_debugging_and_testing">新たな設定項目</a> が追加されました。</li>
</ul>
<h4 id="Web_Workers">Web Workers</h4>
<ul>
<li><a href="/ja/docs/DOM/Worker/Functions_available_to_workers#section_2" title="https://developer.mozilla.org/ja/docs/DOM/Worker/Functions_available_to_workers#section_2">Workers</a> 内で <code>XMLHttpRequest.responseType</code> 属性および <code>XMLHttpRequest.response</code> 属性が利用可能になりました。</li>
<li><a href="/ja/docs/DOM/Worker#Worker()" title="DOM/Worker#Worker()"><code>Worker()</code></a> コンストラクタが <a href="/ja/docs/data_URIs" title="data URIs">data URIs</a> を受け入れるようになりました。</li>
</ul>
<h4 id="IndexedDB">IndexedDB</h4>
<p>IndexedDB を最新のドラフト仕様に更新するための大きな進展がありました。この努力は Firefox 11 でも続くでしょう。</p>
<ul>
<li><a href="/ja/docs/IndexedDB/IDBIndex#count" title="IndexedDB/IDBIndex#count"><code>IDBIndex.count()</code></a> メソッドおよび <a href="/ja/docs/IndexedDB/IDBObjectStore#count" title="IndexedDB/IDBObjectStore#count"><code>IDBObjectStore.count()</code></a> メソッドが追加されました。</li>
<li><a href="/ja/docs/IndexedDB/IDBCursor#advance" title="IndexedDB/IDBCursor#advance"><code>IDBCursor.advance()</code></a> メソッドが追加されました。</li>
<li><a href="/ja/docs/IndexedDB/IDBObjectStore#createIndex" title="https://developer.mozilla.org/ja/docs/IndexedDB/IDBObjectStore#createIndex"><code>IDBObjectStore.createIndex()</code></a> および <a href="/ja/docs/IndexedDB/IDBDatabase#createObjectStore" title="IndexedDB/IDBDatabase#createObjectStore"><code>IDBDatabase.createObjectStore()</code></a> で未知のオプション引数が渡されたとき、Gecko は例外を発生させるのではなくそれを無視するようになりました。</li>
<li><a href="/ja/docs/IndexedDB/IDBTransaction#abort%28%29" title="https://developer.mozilla.org/ja/docs/IndexedDB/IDBTransaction#abort%28%29"><code>IDBTransaction.abort()</code></a> が呼び出されると、待機状態にあるすべての <a href="/ja/docs/IndexedDB/IDBRequest" title="IDBRequest"><code>IDBRequest</code></a> は <code>errorCode</code> を <code>ABORT_ERROR</code> に設定します。</li>
<li><a href="/ja/docs/IndexedDB/IDBObjectStore#delete()" title="IndexedDB/IDBObjectStore#delete()"><code>IDBObjectStore.delete()</code></a> メソッドおよび <a href="/ja/docs/IndexedDB/IDBCursor#delete()" title="IndexedDB/IDBCursor#delete()"><code>IDBCursor.delete()</code></a> メソッドは、戻り値となる <a href="/ja/docs/IndexedDB/IDBRequest" title="IndexedDB/IDBRequest"><code>IDBRequest</code></a> の <code>result</code> 属性の値を <code>undefined</code> にするようになりました。</li>
<li>最新の仕様書で削除されたため、<a href="/ja/docs/IndexedDB/IDBDatabase#setVersion()" title="IndexedDB/IDBDatabase#setVersion()"><code>IDBDatabase.setVersion()</code></a> メソッドは削除されました。データベースのバージョンは、更新された <a href="/ja/docs/IndexedDB/IDBFactory#open" title="IndexedDB/IDBFactory#open"><code>IDBFactory.open()</code></a> メソッドで渡すことができ、<code>onupgradeneeded</code> コールバックでデータベースのスキーマの更新が可能になります。なお、バージョンの型は <code>DOMString</code> から <code>unsigned long long</code> に替わりました。また、<a href="/ja/docs/IndexedDB/IDBVersionChangeRequest" title="IndexedDB/IDBVersionChangeRequest"><code>IDBVersionChangeRequest</code></a> インタフェースは削除され、新たな <a href="/ja/docs/IndexedDB/IDBOpenDBRequest" title="IndexedDB/IDBOpenDBRequest"><code>IDBOpenDBRequest</code></a> インタフェースに置き換えられました。</li>
<li><a href="/ja/docs/IndexedDB/IDBFactory#deleteDatabase%28%29" title="IndexedDB/IDBFactory#deleteDatabase%28%29"><code>IDBFactory.deleteDatabase()</code></a> メソッドが追加されました。</li>
</ul>
<h4 id="その他の変更点">その他の変更点</h4>
<ul>
<li>SVG を含む文字列が与えられたとき、適切な MIMEタイプ <code>image</code><code>/svg+xml</code> が渡された場合は <a href="/ja/docs/DOM/DOMParser#Parsing_a_SVG_document" title="https://developer.mozilla.org/ja/docs/DOM/DOMParser#Parsing_a_SVG_document"><code>DOMParser</code> が <code>SVGDocument</code> を生成する</a>ようになりました。</li>
<li>従来 {{ domxref("element.setAttribute()") }} が整数値の構文解析を行うときは、数値ではない文字列が含まれる場合 (例えば "42foo") にエラーを報告していました。これが仕様書へ合致させるために、数値 42 へ正しく切り詰めるようになりました。</li>
<li>ESC キーで {{ domxref("window.oninput") }} ハンドラが誤って呼び出されるという、間違った結果にならないようになりました。</li>
<li>従来実装されていたものの実際にはアクセスする方法がない {{ domxref("NameList") }} インタフェースは削除されました。</li>
<li>{{ domxref("document.createProcessingInstruction()") }} メソッドが HTML ドキュメントでも、XML ドキュメントの場合と同様に動作するようになりました。{{ domxref("ProcessingInstruction") }} ノードは現在も XML ドキュメントでのみサポートされていますが、ノードはドキュメントをまたいで移動させられますので、HTML ドキュメントでも同様にノードを作成することに役立ちます。</li>
<li>{{ domxref("XMLHttpRequest") }} のプロパティ <code>responseType</code> の値として <a href="/ja/docs/Firefox_9_for_developers#DOM" title="Firefox_9_for_developers#DOM">Firefox 9 で導入した</a> "<code>moz-json</code>" は、最新のドラフト仕様への更新を行い接頭辞を削除しました。{{ bug("707142#c13") }} をご覧ください。</li>
</ul>
<h3 id="CSS">CSS</h3>
<ul>
<li>CSS 3D Transforms がサポートされました。これには {{ cssxref("transform-style") }}、{{ cssxref("perspective") }}、{{ cssxref("perspective-origin") }}、{{ cssxref("backface-visibility") }} の各プロパティ、また同様に {{ cssxref("transform") }} および {{ cssxref("transform-function") }} プロパティによる 3D transform 機能が含まれます。詳しくは <a href="/ja/docs/CSS/Using_CSS_transforms#3D_specific_CSS_properties" title="CSS/Using_CSS_transforms#3D_specific_CSS_properties">Using CSS transforms</a> をご覧ください。</li>
<li>{{ cssxref("unicode-bidi") }} CSS プロパティへ、新たに 2 つの値 <code>-moz-isolation</code> および <code>-moz-plaintext</code> が追加されました。値 <code>-moz-isolation</code> は、要素がその環境から受けるテキストの方向の見解から切り離すことで、異なる方向のテキストであることを示すことができます。<code>unicode-bidi:-moz-isolation</code> を指定した要素は、 {{ HTMLElement("bdi") }} 要素のように動作します。値 <code>-moz-plaintext</code> は、テキストの方向の決定に CSS の {{ cssxref("direction") }} プロパティではなく Unicode のヒューリスティックな方法を用いることを示します。</li>
<li>CSS の {{ cssxref("linear-gradient") }} プロパティおよび {{ cssxref("repeating-linear-gradient") }} プロパティは、新たに <code>to</code> 構文と <em>magic corner</em> アルゴリズムをサポートするよう更新されました。これにより、グラデーションが描画されたボックスの隅へ精密に色を配置することができます。</li>
<li>{{ cssxref("text-overflow") }} プロパティに処理法が一つだけ指定されている場合に、ボックスの両側へオーバーフローする場合の <code>text-overflow</code> の扱いが <a href="/ja/docs/CSS/text-overflow#Gecko_notes" title="CSS/text-overflow#Gecko_notes">正しくなりました</a>。</li>
<li>ポジショニングされた {{ HTMLElement("table") }} 要素内部での {{ cssxref("position") }} プロパティの扱いが <a href="/ja/docs/CSS/position#Gecko_notes" title="CSS/position#Gecko_notes">修正されました</a>。<strong>この変更はページのレイアウトに影響を与えますが、CSS 仕様書や他のブラウザに従うことになりますので、レイアウトの修正は容易でしょう。</strong></li>
<li>{{ HTMLElement("table") }} 要素のマージンの相殺が、CSS 仕様書に合致するようになりました。以前は table 要素のマージンは隣接する要素のマージンと相殺されなかったため、正しくないレイアウトになっていました。<strong>この変更はページのレイアウトに影響を与えますが、CSS 仕様書や他のブラウザに従うことになりますので、レイアウトの修正は容易でしょう。</strong></li>
</ul>
<h3 id="SVG">SVG</h3>
<ul>
<li>最新の SVG 1.1 仕様書へ準拠するため、{{ SVGElement("mask") }} 要素は sRGB および linearRGB をサポートするように更新されました。デフォルトは sRGB です。</li>
</ul>
<h3 id="ネットワーク">ネットワーク</h3>
<ul>
<li>HTTP ヘッダ <code>Accept-Charset</code> は、HTTP 要求時に送信されなくなりました。このヘッダがない場合、サーバは UTF-8 での送信として応答するべきです。</li>
</ul>
<h3 id="開発ツール">開発ツール</h3>
<ul>
<li>{{ domxref("console") }} オブジェクトへ新たに 2 つのメソッド、{{ domxref("console.time()") }} および {{ domxref("console.timeEnd()") }} が追加されました。これらはページにタイマーをセットするために用いられます。</li>
<li>コンテンツの背後にある HTML や CSS の調査および操作を行うすばらしい方法を提供する、<a href="/ja/docs/Tools/Page_Inspector" title="Page Inspector">調査ツール</a> が新たに追加されました。</li>
</ul>
<h2 id="Mozilla_開発者とアドオン開発者向けの変更点">Mozilla 開発者とアドオン開発者向けの変更点</h2>
<p>アドオンを Firefox 10 へ対応させる際に発生すると思われる問題の概要に関しては、<a href="/ja/docs/Firefox/Updating_add-ons_for_Firefox_10" title="Firefox/Updating_add-ons_for_Firefox_10">Updating add-ons for Firefox 10</a> をご覧ください。</p>
<div class="note"><strong>注意:</strong> 古い <a href="/ja/docs/PRBool" title="PRBool"><code>PRBool</code></a> データ形式は退役されました。これを参照する文書では、どこでも代わりに標準 C++ <code>bool</code> 形式を使用します。現時点では文書が更新されていませんが、将来更新されますので留意してください。</div>
<h3 id="Manifests">Manifests</h3>
<ul>
<li>インストールマニフェストに <a href="/ja/docs/Install_Manifests#strictCompatibility" title="Install_Manifests#strictCompatibility"><code><em:strictCompatibility></code></a> のサポートが追加されました。これによりアドオンの作者が、拡張機能で最大バージョンのチェックを有効にすることができます。<code>true</code> に設定すると、アプリケーションのバージョンが <code><em:maxVersion></code> を上回っている場合にアドオンが無効になります。Firefox 10 はデフォルトで、指定された最大バージョンに関わらずアドオンは互換性があるものとします。このフラグは、その設定を上書きします。Firefox の更新により動作しなくなる可能性があることをアドオンで行っている場合はこれを設定するべきですが、アドオンにバイナリコンポーネントが含まれている場合は常に厳密なチェックが行われますのでこれを<strong>設定しない</strong>ようにしてください (バイナリコンポーネントは Firefox のメジャーリリースごとに、必ず再コンパイルが必要です)。</li>
<li>以前の動作、つまりマニフェストの <code>strictCompatibility</code> の値に関わらずすべてのアドオンで厳密な互換性チェックを行う方式に戻したい場合は、設定項目 <code>extensions.strictCompatibility</code> を <code>true</code> にしてください。</li>
</ul>
<h3 id="XUL">XUL</h3>
<ul>
<li><a href="/ja/docs/Chrome_Registration" title="chrome.manifest">chrome.manifest</a> ファイルを用いるブートストラップ型アドオンは、マニフェストファイルが自動的に登録されるようになりました。詳しくは <a href="/ja/docs/Extensions/Bootstrapped_extensions#Adding_user_interface_with_a_chrome.manifest" title="Extensions/Bootstrapped_extensions#Adding_user_interface_with_a_chrome.manifest">Adding user interface with a chrome.manifest</a> をご覧ください。</li>
</ul>
<h3 id="XPConnect">XPConnect</h3>
<ul>
<li><a href="/ja/docs/Components.utils" title="Components.utils"><code>Components.utils</code></a> に、デバッグ用に用意された情報へのアクセスを可能にするプロパティとメソッドがいくつか追加されました。</li>
</ul>
<h3 id="インタフェースの変更">インタフェースの変更</h3>
<ul>
<li>{{ interface("mozISpellCheckingEngine") }} インタフェースおよび {{ interface("nsIEditorSpellCheck") }} インタフェースは、再起動の不要なアドオンがスペルチェッカに辞書を追加できるように更新されました。<strong>注: これを行う方法に関して <a href="/ja/docs/Using_an_External_Spell-checker" title="Using_an_External_Spell-checker">ドキュメントの更新</a> が必要。</strong></li>
<li>{{ ifattribute("nsIBrowserHistory", "lastPageVisited") }} 属性は削除されました。</li>
<li><code>nsIDocumentViewer</code> インタフェースは {{ interface("nsIContentViewer") }} に統合されました。</li>
<li>{{ interface("nsIURIFixup") }} インタフェースに、コンバートする際にプラットフォームの文字コードではなく UTF-8 を使用することを示す <code>FIXUP_FLAG_USE_UTF8</code> フラグが追加されました。</li>
</ul>
<h3 id="プラグインの変更">プラグインの変更</h3>
<ul>
<li>新しい変数 <a href="/ja/docs/Gecko_Plugin_API_Reference/Plug-in_Development_Overview#Working_with_URLs" title="Gecko_Plugin_API_Reference/Plug-in_Development_Overview#Working_with_URLs"><code>NPNVdocumentOrigin</code></a> を追加しました。これはドキュメントの生成元を返すもので、{{ domxref("window.location") }} よりセキュアです。</li>
</ul>
<h3 id="ビルドシステムの変更">ビルドシステムの変更</h3>
<ul>
<li>実際はビルドを成功できないようにしてしまう、<code>--disable-rdf</code> ビルドオプションが削除されました。RDF サポートの完全な削除を可能にする作業は進行中ですが、現在の XUL ではこの機能が必須です。RDF を必要とする最後の痕跡を削除する作業の進捗については {{ bug("559505") }} をご覧ください。</li>
<li><code>--disable-smil</code> ビルドオプションは削除されました。</li>
</ul>
<h2 id="See_also" name="See_also">関連情報</h2>
<div>{{Firefox_for_developers('9')}}</div>
|