handler.getPrototypeOf()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2016.
handler.getPrototypeOf()
メソッドは、オブジェクトの [[GetPrototypeOf]]
内部メソッドに対するトラップです。Object.getPrototypeOf()
などの操作で使用されます。
試してみましょう
構文
js
new Proxy(obj, {
getPrototypeOf(target) {
// …
}
});
引数
次の引数は getPrototypeOf()
メソッドに渡されます。
this
はハンドラーにバインドされます。
target
-
ターゲットオブジェクトです。
返値
getPrototypeOf()
メソッドはオブジェクト、または null
を返さなければなりません。
解説
介入
このトラップは下記の操作に介入できます。
Object.getPrototypeOf()
Reflect.getPrototypeOf()
__proto__
Object.prototype.isPrototypeOf()
instanceof
他にも、[[GetPrototypeOf]]
内部メソッドを呼び出すあらゆる操作に介入できます。
不変条件
以下の不変条件に違反している場合、プロキシーは TypeError
を発生します。
getPrototypeOf
メソッドはオブジェクト、またはnull
を返さなければなりません。target
が拡張不可の場合、Object.getPrototypeOf(proxy)
メソッドはObject.getPrototypeOf(target)
と同じ値を返さなければなりません。
例
基本的な使い方
js
const obj = {};
const proto = {};
const handler = {
getPrototypeOf(target) {
console.log(target === obj); // true
console.log(this === handler); // true
return proto;
},
};
const p = new Proxy(obj, handler);
console.log(Object.getPrototypeOf(p) === proto); // true
getPrototypeOf トラップが発生する5つの方法
js
const obj = {};
const p = new Proxy(obj, {
getPrototypeOf(target) {
return Array.prototype;
},
});
console.log(
Object.getPrototypeOf(p) === Array.prototype, // true
Reflect.getPrototypeOf(p) === Array.prototype, // true
p.__proto__ === Array.prototype, // true
Array.prototype.isPrototypeOf(p), // true
p instanceof Array, // true
);
2 種類の例外
js
const obj = {};
const p = new Proxy(obj, {
getPrototypeOf(target) {
return "foo";
},
});
Object.getPrototypeOf(p); // TypeError: "foo" is not an object or null
const obj = Object.preventExtensions({});
const p = new Proxy(obj, {
getPrototypeOf(target) {
return {};
},
});
Object.getPrototypeOf(p); // TypeError: expected same prototype value
仕様書
Specification |
---|
ECMAScript Language Specification # sec-proxy-object-internal-methods-and-internal-slots-getprototypeof |
ブラウザーの互換性
BCD tables only load in the browser