ES6 Proxy

作者: Cherry丶小丸子 | 来源:发表于2023-02-26 17:32 被阅读0次

Proxy 可以理解成,在目标对象之前架设一层 “拦截”,外界对该对象的访问,都必须先通过这层拦截,因此提供了一种机制,可以对外界的访问进行过滤和改写。Proxy 这个词的原意是代理,用在这里表示由它来 “代理” 某些操作,可以译为 “代理器”

let proxy = new Proxy();

下面是 Proxy 支持的拦截操作一览,一共 13 种

// 拦截对象属性的读取,比如 proxy.foo 和proxy['foo']
get(target, propKey, receiver)

// 拦截对象属性的设置,比如 proxy.foo = v 或 proxy['foo'] = v,返回一个布尔值
set(target, propKey, value, receiver)

// 拦截 propKey in proxy 的操作,返回一个布尔值
has(target, propKey)

// 拦截 delete proxy[propKey] 的操作,返回一个布尔值
deleteProperty(target, propKey)

// 拦截 Object.getOwnPropertyNames(proxy)、Object.getOwnPropertySymbols(proxy)、
// Object.keys(proxy)、for...in循环,返回一个数组
// 该方法返回目标对象所有自身的属性的属性名,
// 而 Object.keys() 的返回结果仅包括目标对象自身的可遍历属性
ownKeys(target)

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

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

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

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

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

// 拦截Object.setPrototypeOf(proxy, proto),返回一个布尔值
// 如果目标对象是函数,那么还有两种额外操作可以拦截
setPrototypeOf(target, proto)

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

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

相关文章

网友评论

      本文标题:ES6 Proxy

      本文链接:https://www.haomeiwen.com/subject/omttldtx.html