Reflect.setPrototypeOf()

これは Harmony(ECMAScript 6) 提案の一部であり、実験段階の技術です。
この技術の仕様は安定していません。ブラウザ互換性の一覧表を確認してください。またこれらの構文や動作は、仕様変更などにより、新しいバージョンのブラウザでは変更される可能性があるという点に注意してください。

静的な Reflect.setPrototypeOf() メソッドは、Object.setPrototypeOf() と同じメソッドです。これは指定されたオブジェクトのプロトタイプ(つまり、内部の [[Prototype]] プロパティ)にほかのオブジェクト、または null を設定します。

構文

Reflect.setPrototypeOf(target, prototype)

パラメータ

target
プロトタイプを設定する対象のオブジェクト。
prototype
オブジェクトの新しいプロトタイプ(オブジェクトか null)。

もどり値

成功裡にプロトタイプが設定されたかどうかを示す Boolean 値。

スローされるエラー

target が Object ではない場合やプロトタイプがオブジェクトでも null でもない場合、 TypeError がスローされる。

説明

メソッドは、指定されたオブジェクトのプロトタイプ(つまり、内部の [[Prototype]] プロパティ)を変更します。

Reflect.setPrototypeOf() を使用する

Reflect.setPrototypeOf({}, Object.prototype); // true

// オブジェクトの [[Prototype]] は null に変更できる。
Reflect.setPrototypeOf({}, null); // true

// 対象が拡張できない場合、false を返す。
Reflect.setPrototypeOf(Object.freeze({}), null); // false

// プロトタイプチェーンが循環する場合、false を返す。
var target = {};
var proto = Object.create(target);
Reflect.setPrototypeOf(target, proto); // false

仕様

仕様 状態 コメント
ECMAScript 2015 (6th Edition, ECMA-262)
The definition of 'Reflect.setPrototypeOf' in that specification.
Standard Initial definition.

ブラウザ実装状況

機能 Chrome Firefox (Gecko) Internet Explorer Opera Safari
基本サポート 未サポート 42 (42) 未サポート 未サポート 未サポート
機能 Android Chrome for Android Firefox Mobile (Gecko) IE Mobile Opera Mobile Safari Mobile
基本サポート 未サポート 未サポート 42.0 (42) 未サポート 未サポート 未サポート

関連項目

ドキュメントのタグと貢献者

 このページの貢献者: YuichiNukiyama
 最終更新者: YuichiNukiyama,