Proxy 代理

Posted 十一云子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Proxy 代理相关的知识,希望对你有一定的参考价值。

Proxy 是代理的构造函数,通过新建对象的形式,对新建的对象的操作进行自定义处理

语法:

  new Promise( target , handler )

target 是拦截操作的目标对象,

handler 是用来自定义代理对象的各种可代理操作.具体使用可参考下面这个例子:

var target = new Proxy(target, {
  "get": function (oTarget, sKey) {
    return oTarget[sKey] || oTarget.getItem(sKey) || undefined;
  },
  "set": function (oTarget, sKey, vValue) {
    if (sKey in oTarget) { return false; }
    return oTarget.setItem(sKey, vValue);
  },
  "deleteProperty": function (oTarget, sKey) {
    if (sKey in oTarget) { return false; }
    return oTarget.removeItem(sKey);
  },
  "enumerate": function (oTarget, sKey) {
    return oTarget.keys();
  },
  "ownKeys": function (oTarget, sKey) {
    return oTarget.keys();
  },
  "has": function (oTarget, sKey) {
    return sKey in oTarget || oTarget.hasItem(sKey);
  },
  "defineProperty": function (oTarget, sKey, oDesc) {
    if (oDesc && "value" in oDesc) { oTarget.setItem(sKey, oDesc.value); }
    return oTarget;
  },
  "getOwnPropertyDescriptor": function (oTarget, sKey) {
    var vValue = oTarget.getItem(sKey);
    return vValue ? {
      "value": vValue,
      "writable": true,
      "enumerable": true,
      "configurable": false
    } : undefined;
  },
});

通过新建对象形式返回对象的handler不能撤销,特意提供了一个API来提供可撤销代理的函数

Proxy.revocable( target , handler )

var revocable = Proxy.revocable({}, {
  get(target, name) {
    return "[[" + name + "]]";
  }
});
var proxy = revocable.proxy;
proxy.foo;              // "[[foo]]"

revocable.revoke();     // 执行撤销方法

proxy.foo;              // TypeError
proxy.foo = 1           // 同样 TypeError
delete proxy.foo;       // 还是 TypeError
typeof proxy            // "object",因为 typeof 不属于可代理操作

 

以上是关于Proxy 代理的主要内容,如果未能解决你的问题,请参考以下文章

代理模式

Mac git代理proxy引起上传代码失败解决办法

设计模式之代理模式(Proxy)详解及代码示例

代理模式(Proxy)

12-代理(Proxy)模式Ruby实现

Proxy模式(代理[延迟]模式)