用Object.create创建对象:
var O = {a: 1};
var n = Object.create(O, {
a: {
value: 2,
enumerable:true
}
});
console.log(n); //{a: 2,a: 1}
console.log(n.a); //2
后定义的a的值为何覆盖不了原型O中a属性的值?
用Object.create创建对象:
var O = {a: 1};
var n = Object.create(O, {
a: {
value: 2,
enumerable:true
}
});
console.log(n); //{a: 2,a: 1}
console.log(n.a); //2
后定义的a的值为何覆盖不了原型O中a属性的值?
谢邀请 ... 但这个问题我无法复现 ...
console.log(n); //{a: 2,a: 1}
{a: 2,a: 1}
这不是一个合法的对象 ... 如果一个对象被这么定义那么它等同与 {a: 1}
...
而问题里输出 n.a 的结果又是 2 ... 所以我觉得这有很大可能性是 console.log
的问题 ...
后面的 a:1
是原型的属性 ... 不是 n 的属性 ... 但是也一并被输出出来了 ...
复现了 ... 上图一目了然 ...
Chrome 27.0.1453.47 beta 可以复现该问题。
v0.8.18 Node.js 下 无法重现。
应该是 console.log 函数的 bug,把原型中的属性给枚举出来了。
Object.create第二个参数添加的属性是实例属性吧。
而O = {a: 1};对于实例来说就是原型对象属性了。
在读取n.a属性时,先从实例查找,查到停止,查不到通过proto在原型链中查找。
所以这里的n.a应该是实例对象属性。实际上并不是覆盖掉。
通过监控看到实例对象n此时有两个属性a和proto内部属性,看到这里你应该明白了。
a 2
proto
a 1
最最重要的是我复制不到你说的情况。
8 回答4.7k 阅读✓ 已解决
6 回答3.4k 阅读✓ 已解决
5 回答2.8k 阅读✓ 已解决
5 回答6.3k 阅读✓ 已解决
4 回答2.3k 阅读✓ 已解决
4 回答2.8k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
你用了其它的基于类的面向对象的语言来思考 javascript。在 javascript 中,没有类,没有覆盖,没有负载,他是基于原型的。
我截了一张图: