【JSリファレンス】setPrototypeOfハンドラー(Proxy)

更新日:2024/06/14

setPrototypeOfハンドラーは、Proxyコンストラクターに渡すハンドラーオブジェクトで使用可能なメソッドです。

Proxyオブジェクト[[SetPrototypeOf]]スロットが呼び出された時、ハンドラーで定義した関数が呼び出されます。

[[SetPrototypeOf]]スロットは、Object.setPrototypeOf()などで、オブジェクトのプロトタイプが変更されるときに呼び出されます。

 

■構文

setPrototypeOf: function ( target, proto ) { }
  1. target: 対象となるオブジェクト
  2. proto: プロトタイプとしてセットするオブジェクト
何らかの値

戻り値はブール値に変換されます。

 

■戻り値の検証

戻り値の変換結果が true 、かつ、targetが拡張不可(Object.isExtensible()の結果がfalse)の場合、以下の検証が行われます。

  • 引数protoと、targetのプロトタイプが一致しない場合、TypeErrorです。

[[SetPrototypeOf]]スロットの戻り値がfalseの場合、Object.setPrototypeOf()は TypeErrorをスローします。

 

■使用例

const obj = {value:100}

const obj1 = {func:()=>"object1"}
const obj2 = {func:()=>"object2"}
const obj3 = {func:()=>"object3"}

const handlerObj = {
      // 特定のオブジェクト以外は排除する
    setPrototypeOf: function ( target, proto ) {
        const allowObj = [obj1,obj2];
        if( !allowObj.includes(proto) ){
            console.log( "そのオブジェクトは使用できません!" );
            return false;
        }
        return Reflect.setPrototypeOf( target, proto );
    }
};
const proxyObj = new Proxy( obj ,handlerObj );
Object.setPrototypeOf(proxyObj,obj1);

console.log( proxyObj.func() );
 // 結果: object1

Object.setPrototypeOf(proxyObj,obj3);
// 結果:
// そのオブジェクトは使用できません!
// TypeError!

 

関連ページ

更新日:2024/06/14

書いた人(管理人):けーちゃん

スポンサーリンク

記事の内容について

null

こんにちはけーちゃんです。
説明するのって難しいですね。

「なんか言ってることおかしくない?」
たぶん、こんなご意見あると思います。

裏付けを取りながら記事を作成していますが、僕の勘違いだったり、そもそも情報源の内容が間違えていたりで、正確でないことが多いと思います。
そんなときは、ご意見もらえたら嬉しいです。

掲載コードについては事前に動作確認をしていますが、貼り付け後に体裁を整えるなどをした結果動作しないものになっていることがあります。
生暖かい視線でスルーするか、ご指摘ください。

ご意見、ご指摘はこちら。
https://jsref.affi-sapo-sv.com/info.php

 

このサイトは、リンクフリーです。大歓迎です。