程序员让前端飞

ES6:proxy代理和Reflect反射

2019-03-14  本文已影响13人  toyfish

在ES6中JavaScript新增了proxy来替代ES5中的Object.defineProperty方法来实现对对象属性的操作。

1、Proxy与Object.defineProperty的比较

Proxy与Object.defineProperty都是用来修改某些操作的默认行为的方法,
在ES6之前使用Object.defineProperty来进行对象属性的拦截操作,比较典型的就是数据的「双向绑定」,Object.defineProperty主要的问题有三个:

2、使用Proxy

const proxy = new Proxy(target,handler)

3、支持的13种API

    const data = {
        val1:1,
        val2:2
    }
    const proxy = new Proxy(data,{
        get(target,key,receiver){
            //可以做一些处理
            return Reflect.get(target,key,receiver)
        },
    })

set()
set方法用来拦截某个属性的赋值操作,可以接受四个参数,依次为目标对象、属性名、属性值和 Proxy 实例本身,其中最后一个参数可选。

    const data = {
        val1:1,
        val2:2
    }
    const proxy = new Proxy(data,{
        set(target,key,val,receiver){
            //可以做一些处理
            return Reflect.set(target,key,val,receiver)
        },
    })

has()
has方法用来查询目标对象是否包含某个属性,可以接受两个参数,一次为目标对象、属性名。

    const data = {
        val1:1,
        val2:2
    }
    const proxy = new Proxy(data,{
        has(target,key){
            //可以做一些处理
            return key in target
        },
    })

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

    const data = {
        val1:1,
        val2:2
    }
    const proxy = new Proxy(data,{
        deleteProperty(target,key){
            //做一些拦截操作
            delete target[key]
            return true
        },
    })

十三个api的用法大同小异,这里简单列举几个,其余的一些根据实际情况选用即可。

4、Reflect 反射
反射的作用是为操作对象而提供的新API。
反射和Proxy是相辅相成的,所使用的API与Proxy相同。

为什么Reflect.set()传入receiver参数,就会触发定义属性的操作?
因为Proxy.set()中的receiver是Proxy的实例,即obj,而Reflect.set一旦传入receiver,就会将属性赋值到receiver上面,也是obj,所以就会触发defineProperty拦截。

上一篇 下一篇

猜你喜欢

热点阅读