Proxy 有一个原始的数据对象,通过代理出来一个新的对象,用户操作的是这个新的对象

{
  let obj ={ time:'2018-01-01', name:'lx' , _r:123 }
  let monitor = new Proxy( obj , {
    get(target , key){ //读取
     return target[key].replace('2018','2017') //把值的2018改成2017
    }
    set(target , key , value){ //设置
     if( key === 'name'){ return target[key] = value } //只允许修改name
      else{ return target[key] }
    }
    has(target , key){ //拦截key in object
     if(key === 'name'){ return target[key] }
      else{ return false }
    }
    deleteProperty(target,key){ //拦截delete
     if(key.indexOf('_')>-1){ delete target[key] ; return true}
      else{ target[key] }
    }
    ownKeys(target){//拦截Object.keys,Objects.getOwnPropertySymbols,Object.getOwnPropertyNames等
      return Object.keys(target).filter(item =>item!='time')
    }
  })
//用户看到和操作的是monitor
  console.log('get' , monitor.time) //2017-01-01
  monitor.time='2019'
  console.log('set', monitor.time) //2017-01-01
  console.log('has', 'name' in monitor , 'time' in monitor) //true false
  delete monitor.time
  console.log('delete', monitor) //time依然存在于monitor
  console.log('ownkeys', Objects.keys(monitor)); //,保护time不显示time
}

Reflect

{
  let obj ={ time:'2018-01-01', name:'lx' , _r:123 };
  console.log( "get" , Reflect.get(obj,'time') ) //"2018-01-01"
  Reflect.set(obj,'name','lmx') ;
  console.log(obj) //{time: "2018-01-01", name: "lmx", _r: 123}
  console.log("has", Reflect.has(obj,'name') ) /true
}
//尽量不对object操作,而是使用Reflect来操作obj

例子:

obj.hasOwnProperty() 指出一个对象是否具有指定名称的属性

两个叹号主要是处理null/undifined/0/""等值,都能转换成布尔值

{
  function validator(target,validator){
    return new Proxy(target,{
      _validator:validator,
     set(target,key,value,Proxy){
    //判断当前对象是否有key值
      if(target.hasOwnProperty(key) ){
      let va = this._validator[key];
      if( !!va(value) ){ //如果值存在
           return Reflect.set(target,key ,value,Proxy)
          }else{ throw Error(` 不能设置${key}到${value} ` )}
        }
        else{ throw Error(` ${key} 不存在 `)}
      }
    })
  }
  const personvalidator={
    name(val){ return typeof val===’string’ } ,
    age(val){ return typeof val===’number’ && val>18}
 }
  class Person{
   constructor(name,age){
    this.name = name;
    this.age = age;
     return validator( this , personvalidator ) //返回的是个Proxy对象
   }
  }
  const person = new Person(‘lx’,30);
  console.log(person)
  person.name = 48 //根据代码throw一个错误
}

ES6的Proxy和Reflect的更多相关文章

  1. es6之proxy和reflect

    一.proxy //Proxy和Reflect //供应商 let obj={ time:"2017-11-21", name:"net", _r:123 } ...

  2. es6之Proxy,Reflect

    Proxy 可以理解成,在目标对象之前架设一层“拦截”,外界对该对象的访问,都必须先通过这层拦截,因此提供了一种机制,可以对外界的访问进行过滤和改写. var proxy = new Proxy(ta ...

  3. ES6初识-Proxy和Reflect

    { let obj={ time:'2017-03-11', name:'net', _r:123 };   let monitor=new Proxy(obj,{ // 拦截对象属性的读取 get( ...

  4. 利用ES6中的Proxy和Reflect 实现简单的双向数据绑定

    利用ES6中的Proxy (代理) 和 Reflect 实现一个简单的双向数据绑定demo. 好像vue3也把 obj.defineProperty()  换成了Proxy+Reflect. 话不多说 ...

  5. ES6入门:数据劫持、Proxy、Reflect

    什么是数据劫持 Object数据劫持实现原理 Array数据劫持的实现原理 Proxy.Reflect 一.什么是数据劫持 定义:访问或者修改对象的某个属性时,在访问和修改属性值时,除了执行基本的数据 ...

  6. ES6(Proxy 和 Reflect)

    Proxy 和 Reflect 1.Proxy 和 Reflect 的概念 Proxy 意为 ‘代理’,连接了用户和真实对象之间的一个层 Reflect 意为‘反射’   反射的是Object 2.适 ...

  7. 005-Symbol、Proxy、Reflect

    1.Symbol:http://es6.ruanyifeng.com/#docs/symbol 2.Proxy:http://es6.ruanyifeng.com/#docs/proxy Proxy ...

  8. babel 不能统编译Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise的问题

    Babel默认只转换新的JavaScript句法(syntax),而不转换新的API,比如Iterator.Generator.Set.Maps.Proxy.Reflect.Symbol.Promis ...

  9. ES6学习笔记(12)----Reflect

    参考书<ECMAScript 6入门>http://es6.ruanyifeng.com/ Reflect 1.概述:Object对象的内部方法都能在Reflect中找到,同时Reflec ...

随机推荐

  1. Android Studio项目Gradle内网配置

    由于内网无法连接到外部网络,在使用Gradle编译Android Studio项目时就会面临一些问题: 1.Gradle安装文件无法下载 2.Gradle Android插件无法下载 3.项目依赖文件 ...

  2. Vue项目中使用webpack配置了别名,引入的时候报错

    chainWebpack(config) { config.resolve.alias .set('@', resolve('src')) .set('assets', resolve('src/as ...

  3. noj算法 迷宫问题 回溯法

    描述: 给一个20×20的迷宫.起点坐标和终点坐标,问从起点是否能到达终点. 输入: 多个测例.输入的第一行是一个整数n,表示测例的个数.接下来是n个测例,每个测例占21行,第一行四个整数x1,y1, ...

  4. yapi部署

    官方提供了两种安装方式,由于环境或者权限问题可能会遇到不少麻烦 最简单的安装方式: 第一种方式 npm install -g yapi-cli --registry https://registry. ...

  5. java---- XMLEncoder 和 XMLDecoder 和 xSteam工具使用

    XMLEncoder: 将对象写入XML数据中 import org.dom4j.DocumentException; import java.beans.XMLEncoder; import jav ...

  6. MySQL视图,函数,触发器,存储过程

    1. 视图 视图是一个虚拟表,它的本质是根据SQL语句获取动态的数据集,并为其命名,用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的临时表摘出来, ...

  7. 配置php5.6.4 + Apache2.4.10

    一.下载并安装apache 下载地址:www.apachelounge.com 解压后:执行以下命令: #httpd.exe –k install #httpd.exe -k start 在执行过程中 ...

  8. Redis在CentOS和Windows安装过程

    redis是一种key-value高效的内存数据库. key-value是什么?json懂吧?字典懂吧?这些都是key-value结构的数据,每个key对应1个value. 那这个数据库和我们网站在使 ...

  9. js编码解码 punyCode

    ;(function(w) { var PunycodeModule = function () { function IdnMapping() { this.utf16 = { decode: fu ...

  10. vba 读取数据库

    1.安装数据库 2.创建数据源 Private Sub Worksheet_Change(ByVal Target As Range) Then Call mySQL End If End Sub P ...