」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何在 JavaScript 中使用代理實作屬性的無此類方法行為?

如何在 JavaScript 中使用代理實作屬性的無此類方法行為?

發佈於2024-11-09
瀏覽:993

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

為屬性實現基於代理的noSuchMethod

JavaScript 中的noSuchMethod 函數允許攔截對不存在方法的調用。然而,是否有類似的屬性機制?

ES6 代理來救援

ES6 代理程式提供了自訂屬性存取的能力。我們可以利用它來模擬屬性的類似 __noSuchMethod__ 的行為:

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);
        };
      }
    }
  });
}

範例實作

以下是使用代理實作可以處理未知屬性的「Dummy」類別的範例:

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");

用法

  • __ownProp1__:記錄現有屬性值。
  • __test__:觸發定義的方法。
  • someName(1, 2)__:使用參數呼叫不存在的方法,由 __noSuchMethod 鉤子處理。
  • __xyz(3, 4)__:與上方類似,但示範了也可以處理非函數屬性。
  • __doesNotExist(" a", "b")__:記錄缺少帶有提供的參數的方法/屬性。
版本聲明 本文轉載於:1729232480如有侵犯,請洽[email protected]刪除
最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3