ECMAScript 6 之Proxy

Proxy

ES6新增了Proxy,那Proxy是什么呢?

Proxy,翻译是代理的意思.在ES6中,Proxy可以监听对象的修改.

也就是说,外界对这个对象的访问与修改,都可以通过Proxy监听,并且可以做一些别的事情.

举个例子:

var obj={
  a:1
}
var proxyObj =  new Proxy(obj,{ //proxyObj会继承obj
    set:function(){
      alert("我被修改了")
    }
  });

  //修改属性
  proxyObj.a=2; //属性被修改后,之前设置的handler会被触发
  console.log(obj.a) // 2

就这么简单


下面是可以监听的操作

1. get(target, propKey, receiver)

拦截对象属性的读取,比如proxy.foo和proxy[‘foo’]。

2. set(target, propKey, value, receiver)

拦截对象属性的设置,比如proxy.foo = v或proxy[‘foo’] = v,返回一个布尔值。

3. has(target, propKey)

拦截propKey in proxy的操作,以及对象的hasOwnProperty方法,返回一个布尔值。

4. deleteProperty(target, propKey)

拦截delete proxy[propKey]的操作,返回一个布尔值。

5. ownKeys(target)

拦截Object.getOwnPropertyNames(proxy)、Object.getOwnPropertySymbols(proxy)、Object.keys(proxy),返回一个数组。该方法返回对象所有自身的属性,而Object.keys()仅返回对象可遍历的属性。

6. getOwnPropertyDescriptor(target, propKey)

拦截Object.getOwnPropertyDescriptor(proxy, propKey),返回属性的描述对象。

7. defineProperty(target, propKey, propDesc)

拦截Object.defineProperty(proxy, propKey, propDesc)、Object.defineProperties(proxy, propDescs),返回一个布尔值。

8. preventExtensions(target)

拦截Object.preventExtensions(proxy),返回一个布尔值。

9. getPrototypeOf(target)

拦截Object.getPrototypeOf(proxy),返回一个对象。

10. isExtensible(target)

拦截Object.isExtensible(proxy),返回一个布尔值。

11. setPrototypeOf(target, proto)

拦截Object.setPrototypeOf(proxy, proto),返回一个布尔值。

如果目标对象是函数,那么还有两种额外操作可以拦截。

12. apply(target, object, args)

拦截Proxy实例作为函数调用的操作,比如proxy(…args)、proxy.call(object, …args)、proxy.apply(…)。

13. construct(target, args)

拦截Proxy实例作为构造函数调用的操作,比如new proxy(…args)。

本文链接:

https://alili.tech/archive/46973069/