Please note, this is a STATIC archive of website developer.mozilla.org from 03 Nov 2016, cach3.com does not collect or store any user information, there is no "phishing" involved.

Revision 1066636 of handler.get()

  • 版本网址缩略名: Web/JavaScript/Reference/Global_Objects/Proxy/handler/get
  • 版本标题: handler.get()
  • 版本 id: 1066636
  • 创建于:
  • 创建者: ngtmuzi
  • 是否是当前版本?
  • 评论 Editorial review completed.

修订内容

{{JSRef}}

handler.get() 方法用于拦截对象的读取属性操作。

语法

var p = new Proxy(target, {
  get: function(target, property, receiver) {
  }
});

参数

以下是传递给get方法的参数,this上下文绑定在handler对象上.

target
目标对象。
property
被获取的属性名。
receiver
Proxy或者继承Proxy的对象

返回值

get方法可以返回任何值。

描述

handler.get 方法用于拦截对象的读取属性操作。

拦截

该方法会拦截目标对象的以下操作:

  • 访问属性: proxy[foo]和 proxy.bar
  • 访问原型链上的属性: Object.create(proxy)[foo]
  • {{jsxref("Reflect.get()")}}

不变量

如果违背了以下的不变量,proxy会抛出 {{jsxref("TypeError")}}:

  • 如果要访问的目标属性是不可写以及不可配置的,则返回的值必须与该目标属性的值相同。
  • 如果要访问的目标属性没有配置访问方法,即get方法是undefined的,则返回值必须为undefined。

示例

以下代码演示如何拦截属性值的读取操作。

var p = new Proxy({}, {
  get: function(target, prop, receiver) {
    console.log("called: " + prop);
    return 10;
  }
});

console.log(p.a); // "called: a"
                  // 10

以下代码演示违反不变量的情况。

var obj = {};
Object.defineProperty(obj, "a", { 
  configurable: false, 
  enumerable: false, 
  value: 10, 
  writable: false 
});

var p = new Proxy(obj, {
  get: function(target, prop) {
    return 20;
  }
});

p.a; //会抛出TypeError

规范

Specification Status Comment
{{SpecName('ES6', '#sec-proxy-object-internal-methods-and-internal-slots-get-p-receiver', '[[Get]]')}} {{Spec2('ES6')}} Initial definition.
{{SpecName('ESDraft', '#sec-proxy-object-internal-methods-and-internal-slots-get-p-receiver', '[[Get]]')}} {{Spec2('ESDraft')}}  

浏览器兼容性

{{CompatibilityTable}}
Feature Chrome Firefox (Gecko) Internet Explorer Opera Safari
Basic support {{CompatUnknown}} {{CompatGeckoDesktop("18")}} {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}}
Feature Android Chrome for Android Firefox Mobile (Gecko) IE Mobile Opera Mobile Safari Mobile
Basic support {{CompatUnknown}} {{CompatUnknown}} {{CompatGeckoMobile("18")}} {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}}

另见

  • {{jsxref("Proxy")}}
  • {{jsxref("Proxy.handler", "handler")}}
  • {{jsxref("Reflect.get()")}}

修订版来源

<div>{{JSRef}}</div>

<p><strong><code>handler.get()</code></strong> 方法用于拦截对象的读取属性操作。</p>

<h2 id="语法">语法</h2>

<pre class="brush: js">var p = new Proxy(target, {
  get: function(target, property, receiver) {
  }
});
</pre>

<h3 id="参数">参数</h3>

<p>以下是传递给get方法的参数,<code>this上下文绑定在</code>handler对象上.</p>

<dl>
 <dt><code>target</code></dt>
 <dd>目标对象。</dd>
 <dt><code>prop</code>erty</dt>
 <dd>被获取的属性名。</dd>
 <dt><code>receiver</code></dt>
 <dd>Proxy或者继承Proxy的对象</dd>
</dl>

<h3 id="返回值">返回值</h3>

<p>get方法可以返回任何值。</p>

<h2 id="描述">描述</h2>

<p><strong><code>handler.get</code></strong> 方法用于拦截对象的读取属性操作。</p>

<h3 id="拦截">拦截</h3>

<p>该方法会拦截目标对象的以下操作:</p>

<ul>
 <li>访问属性: <code>proxy[foo]和</code> <code>proxy.bar</code></li>
 <li>访问原型链上的属性: <code>Object.create(proxy)[foo]</code></li>
 <li>{{jsxref("Reflect.get()")}}</li>
</ul>

<h3 id="不变量">不变量</h3>

<p>如果违背了以下的不变量,proxy会抛出 {{jsxref("TypeError")}}:</p>

<ul>
 <li>如果要访问的目标属性是不可写以及不可配置的,则返回的值必须与该目标属性的值相同。</li>
 <li>如果要访问的目标属性没有配置访问方法,即get方法是undefined的,则返回值必须为undefined。</li>
</ul>

<h2 id="示例">示例</h2>

<p>以下代码演示如何拦截属性值的读取操作。</p>

<pre class="brush: js">var p = new Proxy({}, {
  get: function(target, prop, receiver) {
    console.log("called: " + prop);
    return 10;
  }
});

console.log(p.a); // "called: a"
                  // 10
</pre>

<p>以下代码演示违反不变量的情况。</p>

<pre class="brush: js">var obj = {};
Object.defineProperty(obj, "a", { 
  configurable: false, 
  enumerable: false, 
  value: 10, 
  writable: false 
});

var p = new Proxy(obj, {
  get: function(target, prop) {
    return 20;
  }
});

p.a; //会抛出TypeError
</pre>

<h2 id="规范">规范</h2>

<table class="standard-table">
 <tbody>
  <tr>
   <th scope="col">Specification</th>
   <th scope="col">Status</th>
   <th scope="col">Comment</th>
  </tr>
  <tr>
   <td>{{SpecName('ES6', '#sec-proxy-object-internal-methods-and-internal-slots-get-p-receiver', '[[Get]]')}}</td>
   <td>{{Spec2('ES6')}}</td>
   <td>Initial definition.</td>
  </tr>
  <tr>
   <td>{{SpecName('ESDraft', '#sec-proxy-object-internal-methods-and-internal-slots-get-p-receiver', '[[Get]]')}}</td>
   <td>{{Spec2('ESDraft')}}</td>
   <td> </td>
  </tr>
 </tbody>
</table>

<h2 id="浏览器兼容性">浏览器兼容性</h2>

<div>{{CompatibilityTable}}</div>

<div id="compat-desktop">
<table class="compat-table">
 <tbody>
  <tr>
   <th>Feature</th>
   <th>Chrome</th>
   <th>Firefox (Gecko)</th>
   <th>Internet Explorer</th>
   <th>Opera</th>
   <th>Safari</th>
  </tr>
  <tr>
   <td>Basic support</td>
   <td>{{CompatUnknown}}</td>
   <td>{{CompatGeckoDesktop("18")}}</td>
   <td>{{CompatUnknown}}</td>
   <td>{{CompatUnknown}}</td>
   <td>{{CompatUnknown}}</td>
  </tr>
 </tbody>
</table>
</div>

<div id="compat-mobile">
<table class="compat-table">
 <tbody>
  <tr>
   <th>Feature</th>
   <th>Android</th>
   <th>Chrome for Android</th>
   <th>Firefox Mobile (Gecko)</th>
   <th>IE Mobile</th>
   <th>Opera Mobile</th>
   <th>Safari Mobile</th>
  </tr>
  <tr>
   <td>Basic support</td>
   <td>{{CompatUnknown}}</td>
   <td>{{CompatUnknown}}</td>
   <td>{{CompatGeckoMobile("18")}}</td>
   <td>{{CompatUnknown}}</td>
   <td>{{CompatUnknown}}</td>
   <td>{{CompatUnknown}}</td>
  </tr>
 </tbody>
</table>
</div>

<h2 id="另见">另见</h2>

<ul>
 <li>{{jsxref("Proxy")}}</li>
 <li>{{jsxref("Proxy.handler", "handler")}}</li>
 <li>{{jsxref("Reflect.get()")}}</li>
</ul>
恢复到这个版本