简单实现vue数据双向绑定的原理

vue实现数据双向绑定的原理:就是用 Object.defineproperty() 重新定义对象  设置属性值 (set方法)和 获取属性值(get方法)的操纵来实现的

描述:

Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性,并返回此对象。

语法:

Object.defineProperty(obj, prop, descriptor)

参数:

obj要定义属性的对象。

prop:要定义或修改的属性的名称。

descriptor:要定义或修改的属性描述符。

对象里目前存在的   属性描述符   有两种主要形式:数据描述符存取描述符数据描述符是一个具有值的属性,该值可以是可写的,也可以是不可写的。存取描述符是由 getter 函数和 setter 函数所描述的属性。一个描述符只能是这两者其中之一;不能同时是两者。详情请戳 这里

get属性的 getter 函数,如果没有 getter,则为 undefined。当访问该属性时,会调用此函数。执行时不传入任何参数,但是会传入 this 对象(由于继承关系,这里的this并不一定是定义该属性的对象)。该函数的返回值会被用作属性的值。
默认为 undefined

set属性的 setter 函数,如果没有 setter,则为 undefined。当属性值被修改时,会调用此函数。该方法接受一个参数(也就是被赋予的新值),会传入赋值时的 this 对象。
默认为 undefined

<body>
  <input type="text" id="ipt">
  <p id="p">wade</p>
  <script>
    let obj = {}
    Object.defineProperty(obj,'name',{
      get(){
        console.log('获取了属性值');
        return p.innerHTML
      },
      set(newvalue){
        p.innerHTML = ipt.value = newvalue
        console.log('设置了属性值');
      }
    })
    //获取 obj.name 的值(会执行 get 方法)
    ipt.value = obj.name
    //监听 input 事件  
    ipt.addEventListener('input',(e) => {
      //设置 obj.name 的值(会执行 set 方法)
      obj.name = e.target.value
    })
  </script>
</body>

获取对象 obj.name的值时,会触发 get 方法,得到是 p 标签的内容;

设置对象 obj.name的值时,会触发 set 方法,将 p 标签的内容设置成已经变换的值(用户输入input的内容)。

这样就实现了一个简单的数据双向绑定.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值