Vue 双向绑定原理:数据代理( 双向绑定:数据与页面)

双向绑定的核心: Object.defineProperty()


Object.defineProperty(obj, prop, descriptor)

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

obj:要定义属性的对象
prop:要定义或修改的属性的名称或 Symbol
descriptor:要定义或修改的属性描述符
返回值:被传递给函数的对象

我们通过Object.defineProperty的get方法用来获取值 set方法用来拦截设置值

let number = 18
//定义一个对象,可遍历
var person = {name:'yuroll',sex:'nv'}; 
//添加或修改对象的属性
Object.defineProperty(person, 'age', {
        //value:18,
        //enumerable:true,    //控制属性是否可被枚举,默认为false
        //writable:true,      //控制属性是否可被修改,默认为false
        //configurable:true, //控制属性能否可以被删除,默认为false

        //getter=get函数。必须有return值。读取该属性则被调用~
        get: function () {
            return number;
        },
        //setter=set函数。修改该属性则被调用~且能收到修改的具体值
        set: function (newValue) { 
            number = newValue;
        }
    });
    obj.hello = 'hello world'

vm实例对象的name属性,其实代理是vm._data.name的,只要vm.name修改,则_data同步更新

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值