ホームページ  >  記事  >  ウェブフロントエンド  >  JavaScript でプロキシを使用してプロパティにそのようなメソッドの動作を実装しない方法は?

JavaScript でプロキシを使用してプロパティにそのようなメソッドの動作を実装しない方法は?

Patricia Arquette
Patricia Arquetteオリジナル
2024-10-18 14:22:02761ブラウズ

How to Implement No Such Method Behavior for Properties using Proxies in JavaScript?

プロパティ用のプロキシベースの noSuchMethod の実装

JavaScript の noSuchMethod 機能を使用すると、存在しないメソッドへの呼び出しをインターセプトできます。しかし、プロパティにも同様のメカニズムはありますか?

ES6 Proxies to the Rescue

ES6 Proxies は、プロパティ アクセスをカスタマイズする機能を提供します。これを利用して、プロパティの __noSuchMethod__ のような動作をエミュレートできます。

<code class="javascript">function enableNoSuchMethod(obj) {
  return new Proxy(obj, {
    get(target, p) {
      if (p in target) {
        return target[p];
      } else if (typeof target.__noSuchMethod__ == "function") {
        return function(...args) {
          return target.__noSuchMethod__.call(target, p, args);
        };
      }
    }
  });
}</code>

実装例

これは、プロキシを使用して、未知のプロパティを処理できる「ダミー」クラスを実装する例です。 :

<code class="javascript">function Dummy() {
  this.ownProp1 = "value1";
  return enableNoSuchMethod(this);
}

Dummy.prototype.test = function() {
  console.log("Test called");
};

Dummy.prototype.__noSuchMethod__ = function(name, args) {
  console.log(`No such method ${name} called with ${args}`);
};

var instance = new Dummy();
console.log(instance.ownProp1);
instance.test();
instance.someName(1, 2);
instance.xyz(3, 4);
instance.doesNotExist("a", "b");</code>

使用法

  • __ownProp1__: 既存のプロパティ値をログに記録します。
  • __test__: 定義されたメソッドをトリガーします。
  • someName(1, 2)__: 存在しないメソッドを引数付きで呼び出します。これは __noSuchMethod フックによって処理されます。
  • __xyz(3, 4)__: 上記と似ていますが、 -関数プロパティも処理できます。
  • __doesNotExist("a", "b")__: 指定された引数を持つメソッド/プロパティが存在しないことをログに記録します。

以上がJavaScript でプロキシを使用してプロパティにそのようなメソッドの動作を実装しない方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。