ECMAScript中有两种属性:数据属性和访问器属性;
数据属性的描述符为:Configurable,Enumerable,Writable,Value;
访问器属性的描述符为:Configurable, Enumerable,set,get。
当我们使用new Vue(obj)
,其内部发生了大体如下代码的转换,即将数据属性,转换为了访问器属性
function Vue(obj){
obj.data.keys().forEach((prop, index) => {
Object.defineProperty(obj.data, prop, {
set(){
//可以在此处进行事件监听
},
get(){
}
})
})
return obj;
}
但是当我们后面再次使用普通的赋值,仅仅是赋值了一个数据属性的,这个属性是不会具有访问器属性的事件监听功能的。
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…