美文网首页
vue3.0中为何使用proxy?

vue3.0中为何使用proxy?

作者: 易路先登 | 来源:发表于2019-06-08 17:40 被阅读0次

引子

Object.defineProperty是ES5中的方法,它可以直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象。
用法如下:

   var obj = {
       name:'zhangsan'
   }
  //此后可通过obj.name访问obj的name属性
  //通过obj.name='lisi'来设置obj的name属性

当然也可以通过设置访问器get和set来控制obj对象,用法如下:

Object.defineProperty(obj,"name",{
  set:function(val){
    console.log("赋值时候调用我,我的新值是"+ val)
    },
  get:function(){
    console.log("取值的时候调用我")
    return 123
   }
})

之后通过obj.name访问obj的name属性时会触发get方法,通过obj.name='lisi'的方式设置obj的name属性值时,会触发set方法。貌似没大用,但您不觉得在对象属性值得操作上可以做更多事情了吗?比如你不想让人知道obj的name属性是"张三"。可以修改get方法的逻辑,如下:

get:function(){
    return this.name.replace(/san/,'先生');
}

这样用户在通过obj.name访问obj的name属性时得到的就是"zhang先生",那么set的时候是不是也可以这样弄呢?

重点呀

接上文~:其实都不能,这样会触发循环调用,因为this.name也是对属性的访问啊,也会触发get方法。
那如何实现返回"zhang先生"呢?
拷贝一个对象objCopy,属性和obj要一模一样
如下:

   var objCopy = {
       name:'zhangsan'
   }

在obj的set,get方法里操作它就行了。如下:

Object.defineProperty(obj,"name",{
  set:function(val){
      if(var==='lisi'){
            console.log("誓死不叫这么土的名字")
      }else{
              objCopy.name = val
      }
  },
  get:function(){
    return objCopy.name.replace(/san/,'先生')
   }
})

这样就用两个对象和get,set方法成功的实现了好像是数据劫持或者是代理的这么个操作模式,有没有种娶了媳妇连小姨子也到手的赶脚
把dom数据更新的逻辑写到set或get方法里就实现了当下流行js框架的数据流。
那proxy是个什么东东呢?

Proxy一出,天下我有

此物一出,你再不用费力的去自己克隆一个对象。用法如下:

  var objCopy = new Proxy(obj,{
          get:function(target,key){
                if(key=='name'){
                      return target[key].replace(/san/,'先生');
                }
          },
          set:function(target,key,value){
                if(key == 'name'){
                    value=='lisi'?target[key]:target[key] = value;
                }else{
                    target[key] = value;
                }
          }
   })

get,set方法的target参数即obj对象,key参数是要操作的属性,value参数是赋值动作时的值。
此后,可通过objCopy.name的方式访问obj的name属性,也可以通过objCopy.name='lisi'的方式设置obj的name属性,而且不用给每个属性都设置set,get方法,不会触发循环调用,很是爽的。
这样我们通过对objCopy对象的操作就实现了对obj对象的操作,objCopy对象就是obj对象的代理对象
vue3.0使用了Proxy替换了原先遍历对象使用Object.defineProperty方法给属性添加set,get访问器的笨拙做法。尤大优秀。
本文说了半天,和vue没靠上多少,没办法,热度蹭的不够技巧,我会继续努力的。

相关文章

  • vue3.0中为何使用proxy?

    引子 Object.defineProperty是ES5中的方法,它可以直接在一个对象上定义一个新属性,或者修改一...

  • TypeScript在Vue3.0的Ref类型中的实践

    一、Ref的定义 vue3.0中的响应式原理是基于proxy做的,而使用proxy的前提是,我们要代理的是对象而不...

  • 面试题搜集

    1. vue3 使用proxy解决了什么问题? vue3.0 尝鲜 -- 摒弃 Object.defineProp...

  • ES6的proxy记录

    vue3.0要用proxy来改写取代之前的defineProperty,稍微来记录下Proxy 可以理解成,在目标...

  • Proxy在vue中的应用

    上篇写Object.defineProperty在vue中的应用后,发现vue3.0已经不用这个了,改用Proxy...

  • Vue3.0 API的使用

    Vue3.0 整体优势 proxy数据劫持代替object.defineProperty(特点:可以监听数组变化,...

  • 6道面试题

    Proxy 在2020年来看Proxy早已经不是一个陌生的词了,他能做的是有很多,尤其在Vue3.0通过Proxy...

  • vue3.0 proxy

    vue3 中的 proxyAPI Proxy的监听是针对一个对象的,那么对这个对象的所有操作会进入监听操作。 Pr...

  • Vue3.0双向绑定核心:Proxy 示例

    Vue3.0用Proxy 替代了Object.defineProperty,优化了:无法监听 属性的添加和删除、数...

  • Vue3.0 放弃 Object.defineProperty

    想必大家都知道Vue3.0 把数据对象侦测的API 从Object.defineProperty 换成 proxy...

网友评论

      本文标题:vue3.0中为何使用proxy?

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