廃止
This feature is obsolete. Although it may still work in some browsers, its use is discouraged since it could be removed at any time. Try to avoid using it.
The
handler.enumerate()
メソッドはfor...in
ステートメントにトラップを仕掛けるために使用しますが、ECMAScript標準第7版から削除されブラウザから廃止されました。構文
var p = new Proxy(target, { enumerate(target) { } });
引数
次の引数がenumerate
メソッドに渡されます。this
はハンドラにバインドされます。
target
- ターゲットオブジェクト
戻り値
enumerate
メソッドはiterator オブジェクトを返さなければなりません。
説明
handler.enumerate
メソッドはfor...in
文に対するトラップです。
妨害
このトラップは下記の操作を妨害できます。:
- Property enumeration / for...in:
for (var name in proxy) {...}
Reflect.enumerate()
不変条件
次の不変条件に違反している場合、ProxyはTypeError
をスローします。:
enumerate
メソッドはオブジェクトを返さなければなりません。
例
次のコードではfor...in
文をトラップします。
var p = new Proxy({}, { enumerate(target) { console.log("called"); return ["a", "b", "c"][Symbol.iterator](); } }); for (var x in p) { // "called" console.log(x); // "a" } // "b" // "c"
次のコードでは不変条件に違反します。
var p = new Proxy({}, { enumerate(target) { return 1; } }); for (var x in p) {} // TypeError is thrown
注意: 両方の例ではメソッド定義に対してショートハンドを使用しています。
仕様
仕様 | 状況 | コメント |
---|---|---|
ECMAScript 2015 (6th Edition, ECMA-262) [[Enumerate]] の定義 |
標準 | Initial definition. |
ブラウザ実装状況
機能 | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
基本サポート | ? | 37 (37) | ? | ? | ? |
機能 | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
基本サポート | ? | ? | 37.0 (37) | ? | ? | ? |
関連情報
Proxy
handler
for...in
statementsReflect.enumerate()