美文网首页
ES6中Reflect使用

ES6中Reflect使用

作者: 希染丶 | 来源:发表于2019-06-24 11:00 被阅读0次

    概述

    Reflect对象和Proxy对象一样,也是es6为了操作对象提供的新api
    Reflect对象的设计目的有这样几个:

    1.将object对象的一些明显的属于语音内部的方法(比如Obejct.defineProperty),放到Reflect对象上。
    现阶段,某些方法同时在Object和Reflect对象上部署,未来的新方法只部署在Reflect对象上,也就是说
    从Reflect上可以拿到语言内部的方法

    2.修改某些Object方法的返回结果,让其变的合理。
    比如,Object.defineProperty(obj, name, desc)在无法定义属性时,会抛出一个错误,
    而Reflect.defineProperty(obj, name, desc)则会返回false

    // 老写法
    try{
      Object.defineProperty(target, property, attributes);
      // success
    } catch (e) {
      // failure
    }
    
    // 新写法
    if(Reflect.defineProperty(target, property, attributes)){
      // success
    }else{
      // failure
    }
    

    3.让Object操作都变成函数行为.某些Object操作是命令式,比如 name in obj 和 delete obj[name],
    而Reflect.has(obj, name) 和 Reflect.deleteProperty(obj, name)让它们变成了函数行为

    // 老写法
    'assign' in Object // true
    
    // 新写法
    Reflect.has(Object, 'assign') // true
    
    1. Reflect对象的方法与Proxy对象的方法一一对应,只要是Proxy对象的方法,就能在Reflect对象上找到对应的方法。
      这就让Proxy对象可以方便的调用对应的Reflect方法,完成默认行为,作为修改行为的基础。
      也就是说,不管Proxy怎么修改默认行为,你总可以在Reflect上获取默认行为。
    Proxy(target, {
      set: function(target, name, value, receiver) {
        var success = Reflect.set(target, name, value, receiver);
        if (success) {
          console.log('property ' + name + ' on ' + target + ' set to ' + value);
        }
        return success;
      }
    });
    

    上面代码中,proxy拦截target对象的属性赋值行为。它采用Reflect。set方法将值赋值给对象的属性,确保完成原有的行为,然后再部署额外的功能。

    下面是另一个例子

    var loggedObj = new Proxy(obj, {
      get(target, name) {
        console.log('get', target, name);
        return Reflect.get(target, name);
      },
      deleteProperty(target, name) {
        console.log('delete' + name);
        return Reflect.deleteProperty(target, name);
      },
      has(target, name) {
        console.log('has' + name);
        return Reflect.has(target, name);
      }
    });
    

    每一个Proxy对象的拦截操作(get、delete、has),内部都调用对应的reflect方法。保证原生行为能够正常执行
    添加的工作,就是将每一个操作输出一行日志

    有了Reflect对象以后,很多操作会更容易读

    // 老写法
    Function.prototype.apply.call(Math.floor, undefined, [1.75]) // 1
    
    // 新写法
    Reflect.apply(Math.floor, undefined, [1.75]) // 1
    

    静态方法

    Reflect对象一共有 13 个静态方法。

    Reflect.apply(target, thisArg, args)
    Reflect.construct(target, args)
    Reflect.get(target, name, receiver)
    Reflect.set(target, name, value, receiver)
    Reflect.defineProperty(target, name, desc)
    Reflect.deleteProperty(target, name)
    Reflect.has(target, name)
    Reflect.ownKeys(target)
    Reflect.isExtensible(target)
    Reflect.preventExtensions(target)
    Reflect.getOwnPropertyDescriptor(target, name)
    Reflect.getPrototypeOf(target)
    Reflect.setPrototypeOf(target, prototype)

    大部分与Object对象的同名方法作用相同,而且它与Proxy对象的方法是一一对应的

    相关文章

      网友评论

          本文标题:ES6中Reflect使用

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