浅谈Vue双向绑定与数据代理

Object.defineProperty()

  1. Obejct.defineProperty():定义新属性或修改原有的属性
    1. 语法
      • Obejct.defineProperty(obj, prop, descriptor)
        • obj:必需,目标对象
        • prop:必需,需要定义或者修改的属性的名字
        • descriptor:必需,目标属性所拥有的特性
        • 第三个参数descriptor说明:以对象形式{}书写
    2. 第三个descriptor属性的属性值
      • value:设置属性的值,默认为undefined
      • writable:值是否可以重写,true | false,默认为false
      • enumerable:目标属性是否可以被枚举(遍历),true | false,默认为false
      • configurable:目标属性是否可以被删除或是否可以再次修改特性,true | false,默认false
      • get:值为一个函数,当读取prop属性时,get函数(getter)会被调用,getter的返回值为prop属性的值
      • set:值为一个函数,当修改prop属性的值时,set函数(setter)会被调用,且会收到修改的值
    3. 代码示例:
      const person = {
      	name: '张三',
      	sex: '男'
      }
      Object.defineProperty(person, 'age', {
      	value: 18 // 设置age的属性值
      })
      

双向绑定

  1. Vue的双向绑定原理:Obejct.defineProperty()的getter与setter
    1. vue的数据双向绑定原理本质上是利用definePorperty()的getter(get函数)与setter(set函数)实现的
    2. 代码示例:
      let number = 18
      const person = {
      	name: '张三',
      	sex: '男'
      }
      Object.defineProperty(person, 'age', {
          // 当读取person对象的age属性时触发getter
      	get () {
             console.log('已读取age属性值') 
             return number // 将number的值返回给age属性
          },
          // 当修改person对象的age属性时触发setter,且收到修改的值value
          set (value) {
              console.log('已修改age属性值')
              number = value
          }
      })
      

数据代理

  1. Vue的数据代理:通过一个对象代理对另外一个对象的属性操作(读/写)
  2. 本质:利用defineProperty()的getter(get函数)与setter(set函数)
  3. 代码实例:最简单的数据代理
    const obj = {
    	objname: 'obj'
    }
    const obj2 = {
        obj2name: 'obj2'
    }
    // 让obj2代理obj
    Object.defineProperty(obj2, 'x', {
        get() {
            return obj2.x
        },
        set(vaule) {
            obj.objname = value
        }
    })
    

Vue中的数据代理原理(重点)

  1. vue数据代理原理图
  2. Vue数据代理:通过vm对象代理data中属性的操作(读/写)
    1. 好处:更加方便的操作data中的数据;若不使用数据代理,则在html中使用data中的数据则需要以下列形式:{{_data.name}},而不是{{name}}
  3. 基本原理
    1. 通过Object.defineProperty()方法将data中所有的属性添加到vm(vm._data.name, vm._data.address)之上
    2. 然后为在每一个添加到vm上的属性(name, address)指定setter和getter
    3. 通过getter读取vm._data.name产生vm.name,读取vm._data.address产生vm.address;通过setter改变vm.name的值映射到_data.name改变_data.name,改变_data.address的值改变_data.address
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值