diff options
Diffstat (limited to 'files/ja/web/javascript/reference')
5 files changed, 84 insertions, 66 deletions
diff --git a/files/ja/web/javascript/reference/errors/dead_object/index.html b/files/ja/web/javascript/reference/errors/dead_object/index.html index b45b644b14..febbfbdc95 100644 --- a/files/ja/web/javascript/reference/errors/dead_object/index.html +++ b/files/ja/web/javascript/reference/errors/dead_object/index.html @@ -2,18 +2,19 @@ title: 'TypeError: can''t access dead object' slug: Web/JavaScript/Reference/Errors/Dead_object tags: - - Addon - - Addons - - Error - - Errors - - JavaScript +- Addons +- Error +- Errors +- JavaScript translation_of: Web/JavaScript/Reference/Errors/Dead_object --- <div>{{JSSidebar("Errors")}}</div> -<h2 id="メッセージ">メッセージ</h2> +<p>JavaScript の例外 "can't access dead object" は、メモリ使用量の改善とメモリリークの防止のために、 Firefox がアドオンに対して DOM オブジェクトへの強い参照を保持することを許可しなかったときに発生します。</p> -<pre class="syntaxbox">TypeError: can't access dead object +<h2 id="Message">エラーメッセージ</h2> + +<pre class="brush: js">TypeError: can't access dead object </pre> <h2 id="エラータイプ">エラータイプ</h2> @@ -22,9 +23,11 @@ translation_of: Web/JavaScript/Reference/Errors/Dead_object <h2 id="何がうまくいかなかったのか?">何がうまくいかなかったのか?</h2> -<p>メモリ使用の向上とメモリリーク防止のため、Firefox はアドオンに対して、親ドキュメントが破棄された後に DOM オブジェクトへ強い参照を保持することをできなくしています。死んだオブジェクトは、DOM で棄された後にもかかわらず、存続する DOM 要素への強い参照を保持しています。この問題を回避するために、外部ドキュメント内の DOM ノードへの参照を、そのドキュメントに固有のオブジェクトに格納し、ドキュメントがアンロードされるときにクリーンアップするか、または<a href="/ja/docs/Mozilla/Tech/XPCOM/Language_Bindings/Components.utils.getWeakReference">弱い参照</a>にするべきです。</p> +<p>メモリ使用量の改善とメモリリークの防止のため、 Firefox は、親文書が破棄された後に DOM オブジェクトへの強い参照を保持するアドオンを禁止しています。デッドオブジェクトとは、 DOM で破壊された後も持続する DOM 要素への強力な (keep alive) 参照を保持することです。このような問題を避けるためには、外部の文書の DOM ノードへの参照は、その文書に固有のオブジェクトに保存し、その文書がアンロードされたときにクリーンアップするか、<a href="/ja/docs/Mozilla/Tech/XPCOM/Language_Bindings/Components.utils.getWeakReference">弱い参照</a>として保存する必要があります。 + +<h2 id="Examples">例</h2> -<h2 id="オブジェクトが破棄されているか確認する">オブジェクトが破棄されているか確認する</h2> +<h3 id="Checking_if_an_object_is_dead">オブジェクトが破棄されているかの確認</h3> <p><a href="/ja/docs/Mozilla/Tech/XPCOM/Language_Bindings/Components.utils">Components.utils</a> は特権コードで使用できる <code>isDeadWrapper()</code> メソッドを提供しています。</p> @@ -44,8 +47,8 @@ catch (e) { <h2 id="関連項目">関連項目</h2> <ul> - <li><a href="https://blog.mozilla.org/addons/2012/09/12/what-does-cant-access-dead-object-mean/">What does “can’t access dead object” mean?</a></li> - <li><a href="/ja/docs/Extensions/Common_causes_of_memory_leaks_in_extensions">Common causes of memory leaks in extensions</a></li> - <li><a href="/ja/docs/Mozilla/Tech/XPCOM/Language_Bindings/Components.utils">Components.utils</a></li> - <li><a href="/ja/docs/Mozilla/Zombie_compartments">Zombie Compartments</a></li> + <li><a href="https://blog.mozilla.org/addons/2012/09/12/what-does-cant-access-dead-object-mean/">What does “can’t access dead object” mean?</a></li> + <li><a href="/ja/docs/Extensions/Common_causes_of_memory_leaks_in_extensions">Common causes of memory leaks in extensions</a></li> + <li><a href="/ja/docs/Mozilla/Tech/XPCOM/Language_Bindings/Components.utils">Components.utils</a></li> + <li><a href="/ja/docs/Mozilla/Zombie_compartments">Zombie Compartments</a></li> </ul> diff --git a/files/ja/web/javascript/reference/errors/delete_in_strict_mode/index.html b/files/ja/web/javascript/reference/errors/delete_in_strict_mode/index.html index 0a96a3c13f..9158818092 100644 --- a/files/ja/web/javascript/reference/errors/delete_in_strict_mode/index.html +++ b/files/ja/web/javascript/reference/errors/delete_in_strict_mode/index.html @@ -12,9 +12,12 @@ translation_of: Web/JavaScript/Reference/Errors/Delete_in_strict_mode --- <div>{{jsSidebar("Errors")}}</div> -<h2 id="メッセージ">メッセージ</h2> +<p>JavaScript の <a href="/en-US/docs/Web/JavaScript/Reference/Strict_mode">strict モード</a>専用の例外 "applying the 'delete' operator to an unqualified name is deprecated" は、 <code><a href="/ja/docs/Web/JavaScript/Reference/Operators/delete">delete</a></code> 演算子を用いて変数を削除しようとしたときに発生します。</p> -<pre class="syntaxbox">SyntaxError: applying the 'delete' operator to an unqualified name is deprecated (Firefox) +<h2 id="Message">エラーメッセージ</h2> + +<pre class="brush: js">SyntaxError: Calling delete on expression not allowed in strict mode (Edge) +SyntaxError: applying the 'delete' operator to an unqualified name is deprecated (Firefox) SyntaxError: Delete of an unqualified identifier in strict mode. (Chrome) </pre> @@ -24,17 +27,19 @@ SyntaxError: Delete of an unqualified identifier in strict mode. (Chrome) <h2 id="何がうまくいかなかったのか?">何がうまくいかなかったのか?</h2> -<p>JavaScript では、通常の変数を <code><a href="/ja/docs/Web/JavaScript/Reference/Operators/delete">delete</a></code> 演算子で削除できません。strict モードで、変数を削除しようとするとエラーがスローされ、削除できません。</p> +<p>JavaScript では、通常の変数を <code><a href="/ja/docs/Web/JavaScript/Reference/Operators/delete">delete</a></code> 演算子で削除できません。strict モードで、変数を削除しようとするとエラーが発生し、削除できません。</p> <p><code>delete</code> 演算子は、オブジェクトのプロパティのみ削除できます。オブジェクトプロパティは、設定可能な場合は "修飾" されます。</p> -<p>一般的に信じられていることと異なり、<code>delete</code> 演算子は直接的なメモリーを開放とは<strong>関係ありません</strong>。メモリー管理は、参照の開放によって間接的に行われます。<a href="/ja/docs/Web/JavaScript/Memory_Management">memory management</a> ページと <code><a href="/ja/docs/Web/JavaScript/Reference/Operators/delete">delete</a></code> 演算子ページで詳細を確認してください。</p> +<p>よくある予想とは異なり、 <code>delete</code> 演算子は直接的なメモリーの解放とは<strong>関係ありません</strong>。メモリー管理は、参照の解放によって間接的に行われます。<a href="/ja/docs/Web/JavaScript/Memory_Management">メモリー管理</a>ページと <code><a href="/ja/docs/Web/JavaScript/Reference/Operators/delete">delete</a></code> 演算子ページで詳細を確認してください。</p> <p>このエラーは、<a href="/ja/docs/Web/JavaScript/Reference/Strict_mode">strict mode モード</a>でのみ発生します。非 strict モードでは、演算子はただ <code>false</code> を返します。</p> <h2 id="例">例</h2> -<p>プレーンな変数を削除しようとすると、JavaScript では動作せず、strict モードだとエラーをスローします:</p> +<h3 id="Freeing_the_contents_of_a_variable">変数の内容の解放</h3> + +<p> JavaScript ではプレーンな変数を削除しようとすると動作せず、 strict モードだとエラーをスローします。</p> <pre class="brush: js example-bad">'use strict'; @@ -48,7 +53,7 @@ delete x; // is deprecated </pre> -<p>変数のコンテンツを開放するには、{{jsxref("null")}} を設定します:</p> +<p>変数のコンテンツを解放するには、{{jsxref("null")}} を設定してください。</p> <pre class="brush: js example-good">'use strict'; @@ -65,6 +70,6 @@ x = null; <ul> <li><code><a href="/ja/docs/Web/JavaScript/Reference/Operators/delete">delete</a></code></li> - <li><a href="/ja/docs/Web/JavaScript/Memory_Management">Memory management</a></li> + <li><a href="/ja/docs/Web/JavaScript/Memory_Management">メモリー管理</a></li> <li><a href="/ja/docs/Web/JavaScript/Reference/Errors/Cant_delete">TypeError: property "x" is non-configurable and can't be deleted</a></li> </ul> diff --git a/files/ja/web/javascript/reference/errors/deprecated_tolocaleformat/index.html b/files/ja/web/javascript/reference/errors/deprecated_tolocaleformat/index.html index 685f3537d1..9939c21d2b 100644 --- a/files/ja/web/javascript/reference/errors/deprecated_tolocaleformat/index.html +++ b/files/ja/web/javascript/reference/errors/deprecated_tolocaleformat/index.html @@ -9,22 +9,25 @@ translation_of: Web/JavaScript/Reference/Errors/Deprecated_toLocaleFormat --- <div>{{jsSidebar("Errors")}}</div> -<h2 id="Message" name="Message">メッセージ</h2> +<p>JavaScript の警告 "Date.prototype.toLocaleFormat is deprecated; consider using + Intl.DateTimeFormat instead" は、標準外の {{jsxref("Date.prototype.toLocaleFormat")}} メソッドが使用されたときに発生します。</p> -<pre class="syntaxbox">Warning: Date.prototype.toLocaleFormat is deprecated; consider using Intl.DateTimeFormat instead +<h2 id="Message">エラーメッセージ</h2> + +<pre class="brush: js">Warning: Date.prototype.toLocaleFormat is deprecated; consider using Intl.DateTimeFormat instead </pre> -<h2 id="Error_type" name="Error_type">エラー種別</h2> +<h2 id="Error_type">エラーの種類</h2> -<p>警告。 JavaScript の実行は停止しません。</p> +<p>警告です。 JavaScript の実行は停止しません。</p> -<h2 id="What_went_wrong" name="What_went_wrong">エラーの原因</h2> +<h2 id="What_went_wrong">エラーの原因</h2> -<p>非標準の {{jsxref("Date.prototype.toLocaleFormat")}} メソッドは非推奨のため、使用すべきではありません。これは C 言語の <code>strftime()</code> 関数が期待するものと同じフォーマットの文字列を使用します。<strong>この関数は Firefox 58 以降ではもう利用できません。</strong></p> +<p>非標準の {{jsxref("Date.prototype.toLocaleFormat")}} メソッドは非推奨のため、使用すべきではありません。これは C 言語の <code>strftime()</code> 関数が期待するものと同じフォーマットの文字列を使用します。<strong>この関数は Firefox 58 以降では利用できなくなりました。</strong></p> -<h2 id="Examples" name="Examples">例</h2> +<h2 id="Examples">例</h2> -<h3 id="Deprecated_syntax" name="Deprecated_syntax">非推奨の構文</h3> +<h3 id="Deprecated_syntax">非推奨の構文</h3> <p>{{jsxref("Date.prototype.toLocaleFormat")}} メソッドは非推奨で、削除される予定です (クロスブラウザーの対応はなく、 Firefox でのみ使用できます)。</p> @@ -35,11 +38,11 @@ console.log(date); // In German locale // "Freitag, 10. März 2017"</pre> -<h3 id="ECMAScript_Intl_API_を使用した代わりの標準構文">ECMAScript Intl API を使用した代わりの標準構文</h3> +<h3 id="Alternative_standard_syntax_using_the_ECMAScript_Intl_API">ECMAScript Intl API を使用した代わりの標準構文</h3> -<p>ECMA-402 (ECMAScript Intl API) 標準では、言語に敏感な日付と時刻の書式設定を可能にする標準的なオブジェクトとメソッドを指定しています (Chrome 24+、Firefox 29+、IE11+、Safari10+ で使用できます)。</p> +<p>ECMA-402 (ECMAScript Intl API) 標準では、言語に敏感な日付と時刻の書式設定を可能にする標準的なオブジェクトとメソッドを指定しています (Chrome 24 以降、Firefox 29 以降、IE11 以降、Safari10 以降で使用できます)。</p> -<p>ある日付のフォーマットを指定する場合、{{jsxref("Date.prototype.toLocaleDateString")}} メソッドを使用すべきです。</p> +<p>ある日付のフォーマットを指定する場合、 {{jsxref("Date.prototype.toLocaleDateString")}} メソッドを使用すべきです。</p> <pre class="brush: js example-good">var today = new Date(); var options = { weekday: 'long', year: 'numeric', @@ -50,7 +53,7 @@ console.log(date); // "Freitag, 10. März 2017" </pre> -<p>または、{{jsxref("DateTimeFormat", "Intl.DateTimeFormat")}} オブジェクトを使用できます。これにより、ほとんど計算が完了したオブジェクトをキャッシュして、書式設定が高速になります。これは、日付のフォーマットを繰り返すときに役立ちます。</p> +<p>または、 {{jsxref("Intl/DateTimeFormat", "Intl.DateTimeFormat")}} オブジェクトを使用できます。これにより、ほとんど計算が完了したオブジェクトをキャッシュして、書式設定が高速になります。これは、日付の書式化を繰り返すときに役立ちます。</p> <pre class="brush: js example-good">var options = { weekday: 'long', year: 'numeric', month: 'long', day: 'numeric' }; @@ -65,7 +68,7 @@ dates.forEach(date => console.log(dateFormatter.format(date))); // "Montag, 12. Mai 2014" </pre> -<h3 id="Alternative_standard_syntax_using_Date_methods" name="Alternative_standard_syntax_using_Date_methods">Date メソッドを使用した代わりの標準構文</h3> +<h3 id="Alternative_standard_syntax_using_Date_methods">Date メソッドを使用した代わりの標準構文</h3> <p>{{jsxref("Date")}} オブジェクトは、カスタム日付文字列を構築するいくつかのメソッドを提供しています。</p> @@ -82,10 +85,10 @@ let date = now.getFullYear() * 10000 + console.log(date); // "20170310"</pre> -<h2 id="See_also" name="See_also">関連情報</h2> +<h2 id="See_also">関連情報</h2> <ul> - <li>{{jsxref("Date.prototype.toLocaleFormat")}}</li> - <li>{{jsxref("Date.prototype.toLocaleDateString")}}</li> - <li>{{jsxref("DateTimeFormat", "Intl.DateTimeFormat")}}</li> + <li>{{jsxref("Date.prototype.toLocaleFormat")}}</li> + <li>{{jsxref("Date.prototype.toLocaleDateString")}}</li> + <li>{{jsxref("Intl/DateTimeFormat", "Intl.DateTimeFormat")}}</li> </ul> diff --git a/files/ja/web/javascript/reference/errors/equal_as_assign/index.html b/files/ja/web/javascript/reference/errors/equal_as_assign/index.html index e8fa400bf1..f123401d42 100644 --- a/files/ja/web/javascript/reference/errors/equal_as_assign/index.html +++ b/files/ja/web/javascript/reference/errors/equal_as_assign/index.html @@ -2,6 +2,7 @@ title: 'SyntaxError: test for equality (==) mistyped as assignment (=)?' slug: Web/JavaScript/Reference/Errors/Equal_as_assign tags: + - Error - Errors - JavaScript - SyntaxError @@ -9,46 +10,47 @@ translation_of: Web/JavaScript/Reference/Errors/Equal_as_assign --- <div>{{jsSidebar("Errors")}}</div> -<h2 id="メッセージ">メッセージ</h2> +<p>JavaScript の警告 "test for equality (==) mistyped as assignment (=)?" は、代入 (<code>=</code>) が通常は等価性 (<code>==</code>) の検査をすべき場面にあった場合に発生します。</p> -<pre class="syntaxbox">Warning: SyntaxError: test for equality (==) mistyped as assignment (=)? +<h2 id="Message">エラーメッセージ</h2> + +<pre class="brush: js">Warning: SyntaxError: test for equality (==) mistyped as assignment (=)? </pre> <h2 id="エラータイプ">エラータイプ</h2> -<p><a href="/ja/docs/Web/JavaScript/Reference/Strict_mode">strict モード</a> でのみ、{{jsxref("SyntaxError")}} の警告が出ます。</p> +<p>(Firefox のみ) {{jsxref("SyntaxError")}} の警告であり、 <code>javascript.options.strict</code> の設定が <code>true</code> に設定されていた場合に発生します。</p> <h2 id="何がうまくいかなかったのか?">何がうまくいかなかったのか?</h2> -<p>通常、等価テスト(<code>==</code>)が予想されるところで、代入 (<code>=</code>)が行われています。デバッグを行いやすくするために、(厳密な警告が可能になっている)JavaScript は、このパターンについて警告を出します。</p> +<p>代入 (<code>=</code>) が通常は等価性 (<code>==</code>) の検査をすべき場面にあった場合に発生します。デバッグを行いやすくするために、 JavaScript は (厳密な警告が有効な場合は) このパターンについて警告を出します。</p> <h2 id="例">例</h2> -<h3 id="条件式内での代入">条件式内での代入</h3> +<h3 id="Assignment_within_conditional_expressions">条件式内での代入</h3> -<p>(<code><a href="/ja/docs/Web/JavaScript/Reference/Statements/if...else">if...else</a></code> のような)条件式内で、ダン純名代入を行わないことをお勧めします。なぜならば、コードを一目見たときに、代入は等価と混同しやすいからです。たとえば、次のコードは使用しないでください:</p> +<p>(<code><a href="/ja/docs/Web/JavaScript/Reference/Statements/if...else">if...else</a></code> のような) 条件式内では、単純な代入を行わないことをお勧めします。コードを一目見たときに、代入は等価と混同しやすいからです。たとえば、以下のコードは使用しないでください。</p> <pre class="brush: js example-bad">if (x = y) { - // 正しいことを実行する。 + // 正しいことを実行する } </pre> -<p>条件式内で代入をする必要がある場合、一般t京奈方法は代入の周りに追加の括弧を置くことです。たとえば:</p> +<p>条件式内で代入を行う必要がある場合、一般的には次のように、代入の周りに追加の括弧を置きます。</p> <pre class="brush: js">if ((x = y)) { - // 正しいことを実行する。 + // 正しいことを実行する }</pre> -<p>または、, 比較演算(たとえば、<code>==</code> や <code>===</code>)を使用したいのかもしれません:</p> +<p>または、本当は比較演算子 (<code>==</code> や <code>===</code> など) を使用しようとしたのかもしれません。</p> <pre class="brush: js">if (x == y) { - // 正しいことを実行する。 + // 正しいことを実行する }</pre> <h2 id="関連項目">関連項目</h2> <ul> - <li><a href="/ja/docs/Web/JavaScript/Reference/Strict_mode">Strict モード</a></li> <li><code><a href="/ja/docs/Web/JavaScript/Reference/Statements/if...else">if...else</a></code></li> - <li><a href="/ja/docs/Web/JavaScript/Reference/Operators/Comparison_Operators">比較演算子</a></li> + <li><a href="/ja/docs/Web/JavaScript/Reference/Operators#equality_operators">等価演算子</a></li> </ul> diff --git a/files/ja/web/javascript/reference/errors/getter_only/index.html b/files/ja/web/javascript/reference/errors/getter_only/index.html index 831fb54785..bbd0fcb443 100644 --- a/files/ja/web/javascript/reference/errors/getter_only/index.html +++ b/files/ja/web/javascript/reference/errors/getter_only/index.html @@ -2,32 +2,37 @@ title: 'TypeError: setting getter-only property "x"' slug: Web/JavaScript/Reference/Errors/Getter_only tags: - - Error - - Errors - - JavaScript - - Strict Mode - - TypeError +- Error +- Errors +- JavaScript +- Strict Mode +- TypeError translation_of: Web/JavaScript/Reference/Errors/Getter_only --- <div>{{jsSidebar("Errors")}}</div> -<h2 id="メッセージ">メッセージ</h2> +<p>JavaScript の <a href="/ja/docs/Web/JavaScript/Reference/Strict_mode">strict モード</a>専用の例外 "setting getter-only property" は、<a href="/ja/docs/Web/JavaScript/Reference/Functions/get">ゲッター</a>のみが定義されているプロパティに新しい値を設定しようとした時に発生します。</p> -<pre class="syntaxbox">TypeError: setting getter-only property "x" (Firefox) +<h2 id="Message">エラーメッセージ</h2> + +<pre class="brush: js">TypeError: Assignment to read-only properties is not allowed in strict mode (Edge) +TypeError: setting getter-only property "x" (Firefox) TypeError: Cannot set property "prop" of #<Object> which has only a getter (Chrome) </pre> -<h2 id="エラータイプ">エラータイプ</h2> +<h2 id="Error_type">エラーの種類</h2> <p><a href="/ja/docs/Web/JavaScript/Reference/Strict_mode">strict モード</a>でのみ、{{jsxref("TypeError")}}。</p> -<h2 id="何がうまくいかなかったのか?">何がうまくいかなかったのか?</h2> +<h2 id="What_went_wrong">エラーの原因</h2> + +<p><a href="/ja/docs/Web/JavaScript/Reference/Functions/get">ゲッター</a>のみが定義されているプロパティに、新しい値を設定しようとしています。非 strict モードでは暗黙裡に無視されるだけですが、 <a href="/ja/docs/Web/JavaScript/Reference/Strict_mode">strict モード</a>では {{jsxref("TypeError")}} が発生します。</p> -<p><a href="/ja/docs/Web/JavaScript/Reference/Functions/get">getter</a> しか指定されていないプロパティに、新しい値を設定しようとしています。非 strict モードでは暗黙裡に無視されるだけですが、<a href="/ja/docs/Web/JavaScript/Reference/Strict_mode">strict モード</a>では {{jsxref("TypeError")}} がスローされます。</p> +<h2 id="Examples">例</h2> -<h2 id="例">例</h2> +<h3 id="Property_with_no_setter">セッターのないプロパティ</h3> -<p>下記の例では、プロパティの getter の設定方法を示しています。<a href="/ja/docs/Web/JavaScript/Reference/Functions/set">setter</a> は指定していないため、<code>temperature</code> プロパティに <code>30</code> をセットしようとすると、<code>TypeError</code> がスローされます。詳細は {{jsxref("Object.defineProperty()")}} ページを見てください。</p> +<p>下記の例では、プロパティのゲッターの設定方法を示しています。<a href="/ja/docs/Web/JavaScript/Reference/Functions/set">セッター</a>を指定していないため、 <code>temperature</code> プロパティに <code>30</code> を設定しようとすると、<code>TypeError</code> が発生します。詳細は {{jsxref("Object.defineProperty()")}} ページを見てください。</p> <pre class="brush: js example-bad">"use strict"; @@ -47,7 +52,7 @@ arc.temperature; // 'get!' arc.temperature = 30; // TypeError: setting getter-only property "temperature"</pre> -<p>このエラーを修正するには、temperature プロパティに値を設定しようとしている 16 行目を取り除くか、次のように <a href="/ja/docs/Web/JavaScript/Reference/Functions/set">setter</a> を実装します:</p> +<p>このエラーを修正するには、 temperature プロパティに値を設定しようとしている 16 行目を取り除くか、次のように<a href="/ja/docs/Web/JavaScript/Reference/Functions/set">セッター</a>を実装します。</p> <pre class="brush: js example-good highlight[12]">"use strict"; @@ -75,9 +80,9 @@ arc.temperature = 11; arc.temperature = 13; arc.getArchive(); // [{ val: 11 }, { val: 13 }]</pre> -<h2 id="関連項目">関連項目</h2> +<h2 id="See_also">関連項目</h2> <ul> - <li>{{jsxref("Object.defineProperty()")}}</li> - <li>{{jsxref("Object.defineProperties()")}}</li> + <li>{{jsxref("Object.defineProperty()")}}</li> + <li>{{jsxref("Object.defineProperties()")}}</li> </ul> |