Proxy拦截器

Proxy 对象用于创建一个对象的代理,从而实现基本操作的拦截和自定义(如属性查找、赋值、枚举、函数调用等)。

  • 语法
  • target
    要使用 Proxy 包装的目标对象(可以是任何类型的对象,包括原生数组,函数,甚至另一个代理)。
  • handler
    一个通常以函数作为属性的对象,各属性中的函数分别定义了在执行各种操作时代理 p 的行为。
    const p = new Proxy(target, handler)
    // target: 所要拦截的目标对象(可以是任何类型的对象,包括原生数组,函数,甚至另一个代理)
    // handler:一个对象,定义要拦截的行为
    
  • Proxy.revocable()
    创建一个可撤销的Proxy对象。
    

捕捉器

  • handler.getPrototypeOf()
    Object.getPrototypeOf 方法的捕捉器。
    Object.getPrototypeOf() 方法返回指定对象的原型(内部[[Prototype]]属性的值)
    
    handler.setPrototypeOf()
    Object.setPrototypeOf 方法的捕捉器。
    
    handler.isExtensible()
    Object.isExtensible 方法的捕捉器。
    
    handler.preventExtensions()
    Object.preventExtensions 方法的捕捉器。
    
    handler.getOwnPropertyDescriptor()
    Object.getOwnPropertyDescriptor 方法的捕捉器。
    
    handler.defineProperty()
    Object.defineProperty 方法的捕捉器。
    
    handler.has()
    in 操作符的捕捉器。
    
    handler.get()
    属性读取操作的捕捉器。
    
    handler.set()
    属性设置操作的捕捉器。
    
    handler.deleteProperty()
    delete 操作符的捕捉器。
    
    handler.ownKeys()
    Object.getOwnPropertyNames 方法和 Object.getOwnPropertySymbols 方法的捕捉器。
    
    handler.apply()
    函数调用操作的捕捉器。
    
    handler.construct()
    new 操作符的捕捉器。
    
  • 示例
    const handler = {
        get: function(obj, prop) {
        //obj是实例对象 prop是现在访问的属性名
        // 这里可以对应该返回的prop进行修改
            return prop in obj ? obj[prop] : 37;
        }
    };
    
    const p = new Proxy({}, handler);
    p.a = 1;
    p.b = undefined;
    
    console.log(p.a, p.b);      // 1, undefined
    console.log('c' in p, p.c); // false, 37
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值