aboutsummaryrefslogtreecommitdiff
path: root/files/ja/web/javascript
diff options
context:
space:
mode:
Diffstat (limited to 'files/ja/web/javascript')
-rw-r--r--files/ja/web/javascript/reference/global_objects/reflect/get/index.html89
1 files changed, 48 insertions, 41 deletions
diff --git a/files/ja/web/javascript/reference/global_objects/reflect/get/index.html b/files/ja/web/javascript/reference/global_objects/reflect/get/index.html
index 9ad5516167..7f2ed12f49 100644
--- a/files/ja/web/javascript/reference/global_objects/reflect/get/index.html
+++ b/files/ja/web/javascript/reference/global_objects/reflect/get/index.html
@@ -2,53 +2,51 @@
title: Reflect.get()
slug: Web/JavaScript/Reference/Global_Objects/Reflect/get
tags:
- - ECMAScript 2015
- - JavaScript
- - Method
- - Reference
- - Reflect
- - メソッド
+- ECMAScript 2015
+- JavaScript
+- Method
+- Reference
+- Reflect
+- メソッド
translation_of: Web/JavaScript/Reference/Global_Objects/Reflect/get
---
<div>{{JSRef}}</div>
-<p>静的な <strong><code>Reflect.get()</code></strong> メソッドは、オブジェクト (<code>target[propertyKey]</code>) からプロパティを関数として取得するように動作します。動作します。</p>
+<p>静的な <strong><code>Reflect.get()</code></strong> メソッドは、オブジェクト (<code>target[propertyKey]</code>) からプロパティを関数として取得するように動作します。</p>
<div>{{EmbedInteractiveExample("pages/js/reflect-get.html")}}</div>
-<p class="hidden">このデモのソースファイルは GitHub リポジトリに格納されています。デモプロジェクトに協力したい場合は、 <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples</a> をクローンしてプルリクエストを送信してください。</p>
+<h2 id="Syntax">構文</h2>
-<h2 id="Syntax" name="Syntax">構文</h2>
-
-<pre class="syntaxbox">Reflect.get(<var>target</var>, <var>propertyKey</var>[, <var>receiver</var>])
+<pre class="brush: js">Reflect.get(<var>target</var>, <var>propertyKey</var>[, <var>receiver</var>])
</pre>
-<h3 id="Parameters" name="Parameters">引数</h3>
+<h3 id="Parameters">引数</h3>
<dl>
- <dt><code><var>target</var></code></dt>
- <dd>プロパティを取得する対象のオブジェクト。</dd>
- <dt><code><var>propertyKey</var></code></dt>
- <dd>設定するプロパティ名。</dd>
- <dt><code><var>receiver</var></code> {{optional_inline}}</dt>
- <dd>ゲッターがあった場合、 <code><var>target</var></code> への呼び出しで使用する <code>this</code> の値を提供します。 {{jsxref("Proxy")}} とともに使用すると、 <code><var>target</var></code> から継承しているオブジェクトにすることができます。</dd>
+ <dt><code><var>target</var></code></dt>
+ <dd>プロパティを取得する対象のオブジェクト。</dd>
+ <dt><code><var>propertyKey</var></code></dt>
+ <dd>設定するプロパティ名。</dd>
+ <dt><code><var>receiver</var></code> {{optional_inline}}</dt>
+ <dd>ゲッターがあった場合、 <code><var>target</var></code> への呼び出しで使用する <code>this</code> の値を提供します。 {{jsxref("Proxy")}} とともに使用すると、 <code><var>target</var></code> から継承しているオブジェクトにすることができます。</dd>
</dl>
-<h3 id="Return_value" name="Return_value">返値</h3>
+<h3 id="Return_value">返値</h3>
<p>プロパティの値です。</p>
-<h3 id="Exceptions" name="Exceptions">例外</h3>
+<h3 id="Exceptions">例外</h3>
-<p><code><var>target</var></code> が {{jsxref("Object")}} でなかった場合、 {{jsxref("TypeError")}} が発生します。。</p>
+<p><code><var>target</var></code> が {{jsxref("Object")}} でなかった場合、 {{jsxref("TypeError")}} が発生します。</p>
-<h2 id="Description" name="Description">解説</h2>
+<h2 id="Description">解説</h2>
-<p><code>Reflect.get</code> メソッドはオブジェクトのプロパティを取得します。機能としては{{jsxref("Operators/Property_Accessors", "プロパティアクセサー", "", 1)}}構文と似ています。</p>
+<p><code>Reflect.get</code> メソッドはオブジェクトのプロパティを取得します。機能としては<a href="/ja/docs/Web/JavaScript/Reference/Operators/Property_Accessors">プロパティアクセサー</a>構文と似ています。</p>
-<h2 id="Examples" name="Examples">例</h2>
+<h2 id="Examples">例</h2>
-<h3 id="Using_Reflect.get" name="Using_Reflect.get"><code>Reflect.get()</code> の使用</h3>
+<h3 id="Using_Reflect.get"><code>Reflect.get()</code> の使用</h3>
<pre class="brush: js">// オブジェクト
let obj = { x: 1, y: 2 }
@@ -66,32 +64,41 @@ let obj = new Proxy(x, {
  }
})
Reflect.get(obj, 'foo') // "foobar"
+
+//Proxy with get handler and receiver
+let x = {p: 1, foo: 2};
+let y = {foo: 3};
+
+let obj = new Proxy(x, {
+ get(t, prop, receiver) {
+ return receiver[prop] + 'bar'
+ }
+})
+Reflect.get(obj, 'foo', y) // "3bar"
</pre>
-<h2 id="Specifications" name="Specifications">仕様書</h2>
+<h2 id="Specifications">仕様書</h2>
<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">仕様書</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-reflect.get', 'Reflect.get')}}</td>
- </tr>
- </tbody>
+ <thead>
+ <tr>
+ <th scope="col">仕様書</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td>{{SpecName('ESDraft', '#sec-reflect.get', 'Reflect.get')}}</td>
+ </tr>
+ </tbody>
</table>
-<h2 id="Browser_compatibility" name="Browser_compatibility">ブラウザーの互換性</h2>
-
-<div class="hidden">このページの互換性一覧表は構造化データから生成されています。データに協力していただけるのであれば、 <a class="external" href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> をチェックアウトしてプルリクエストを送信してください。</div>
+<h2 id="Browser_compatibility">ブラウザーの互換性</h2>
<p>{{Compat("javascript.builtins.Reflect.get")}}</p>
<h2 id="See_also" name="See_also">関連情報</h2>
<ul>
- <li>{{jsxref("Reflect")}}</li>
- <li><a href="/ja/docs/Web/JavaScript/Reference/Operators/Property_Accessors">プロパティアクセサー</a></li>
+ <li>{{jsxref("Reflect")}}</li>
+ <li><a href="/ja/docs/Web/JavaScript/Reference/Operators/Property_Accessors">プロパティアクセサー</a></li>
</ul>