ES5 set如何设置值?
代码是这样的
function(){
window.Observer = function(data){
this.data=data;
for(var key in this.data){
var val = this.data[key]; ---这里
this.walk(val,key);
}
};
Observer.prototype.walk = function(val,key){
Object.defineProperty(this.data,key,{
enumerable: true,
configurable: true,
get:function(){
return val;
},
set:function(newValue){
val = newValue; --- 这里
}
})
};
})()
var app = new Observer({a:"a"});
console.info(app.data.a);
app.data.a = "b";
console.info(app.data.a);
然后输出为 a b;
为什么通过val = newValue可以设置a属性的值?
val难道是一个引用?
如果val存的是地址,可是这样为什么又不行
var a = {b:0}
var val = a.b;
val = 1
//a.b仍然是0
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
找到答案了,,, val不是引用,就是值 ,之所以通过val = newValue可以设置app.data.a的值,是因为这是个闭包,里面保存了val的值,所以获得app.data.a的值时,调用get方法,返回的也是val.
参考 Object.defineProperty()
另外,下面的例子你是对变量重新赋值
第一个问题解决:
在你这段代码(定义对象属性),val就是引用,你说对了;当你对一个对象的属性赋值时,就会调用对象属性的set方法。
第二个问题解决:
你这段代码都没有修改过a.b的值,如果你想修改a.b的值,代码如下: