加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

vue源码学习之Object.defineProperty对象属性监听

发布时间:2020-12-17 03:12:35 所属栏目:百科 来源:网络整理
导读:本文介绍了vue源码学习之Object.defineProperty对象属性监听,分享给大家,具体如下: 参考版本 vue源码版本:0.11 相关 vue实现双向数据绑定的关键是 Object.defineProperty ,让我们先来看下这个函数。 在MDN上查看有关Object.defineProperty 的解释。 我

本文介绍了vue源码学习之Object.defineProperty对象属性监听,分享给大家,具体如下:

参考版本 vue源码版本:0.11

相关

vue实现双向数据绑定的关键是 Object.defineProperty ,让我们先来看下这个函数。

在MDN上查看有关Object.defineProperty 的解释。

我们先从最简单的开始:

new Observer(val);
}
this.convert(key,val);
}
}
};

p.convert = function(key,val){
Object.defineProperty(this.data,key,{
enumerable: false,get: function(){
console.log(key + '被访问');
},set: function(newVal){
console.log(key + '被修改,新' + key + '=' + newVal);
if(newVal === val) return ;
val = newVal;
}
})
};

let data = {
user: {
name: 'zhangsan',age: 14
},address: {
city: 'beijing'
}
}

let app = new Observer(data);
data.user.name; // user被访问

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读