この記事は編集レビューを必要としています。ぜひご協力ください。
この翻訳は不完全です。英語から この記事を翻訳 してください。
これは Harmony(ECMAScript 6) 提案の一部であり、実験段階の技術です。
この技術の仕様は安定していません。ブラウザ互換性の一覧表を確認してください。またこれらの構文や動作は、仕様変更などにより、新しいバージョンのブラウザでは変更される可能性があるという点に注意してください。
概要
プロパティ値を取得することに対するトラップです。
構文
var p = new Proxy(target, { get: function(target, property, receiver) { } });
引数
次の引数がget
メソッドに渡されます。this
はハンドラにバインドされます。
target
- ターゲットオブジェクト
prop
erty- 取得するプロパティの名称
receiver
- プロキシかプロキシから継承するオブジェクトのどちらか
戻り値
get
メソッドはどんな値でも返すことができます。
説明
handler.get
メソッドはプロパティ値を取得することに対するトラップです。
インターセプト
このトラップは次の操作をインターセプトできます。:
- プロパティアクセス:
proxy[foo]
andproxy.bar
- 継承したプロパティアクセス:
Object.create(proxy)[foo]
Reflect.get()
不変条件
次の不変条件に違反している場合、プロキシはTypeError
をスローします。:
- ターゲットオブジェクトプロパティが書き込み不可で非設定なデータプロパティなら、プロパティに対して報告される値は対応するターゲットオブジェクトプロパティと同じでなければなりません。
- 対応するターゲットオブジェクトプロパティが[[Get]]属性として未定義で非設定なアクセスプロパティなら、プロパティに対して報告される値は未定義でなければなりません。
例
次のコードではプロパティを取得してトラップします。
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 is thrown
仕様
仕様 | 状況 | コメント |
---|---|---|
ECMAScript 2015 (6th Edition, ECMA-262) The definition of '[[Get]]' in that specification. |
Standard | Initial definition. |
ブラウザ実装状況
機能 | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
基本サポート | ? | 18 (18) | ? | ? | ? |
機能 | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
基本サポート | ? | ? | 18.0 (18) | ? | ? | ? |