Javascript-Ausgabewert
迷茫
迷茫 2017-06-12 09:30:19
0
3
720

var a={},
b={key:'b'},
c={key:'c'};

a[b]=123;
a[c]=456;

console.log(a[b]);//Die Ausgabe ist 456.
Ich verstehe nicht, warum das Ausgabeergebnis 456 ist. Bitte helfen Sie mir bei der Erklärung..

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

Antworte allen(3)
黄舟

Javascript 中,当通过 [] 访问对象属性时, 方括号中的表达式将会被求值并被转换成一个字符串,调用它的toString方法.
所以:

var a = {};
b={key:'b'};
console.log(b.toString()); // [object Object]
a[b]=123;
console.log(typeof Object.keys(a)[0]);    // string, 属性名 b 转换成了字符串.

所以 bc 均转换成相同的字符串 [object Object]. 所以再次赋值就会被覆盖.

曾经蜡笔没有小新

a[b]=123;这一步之后你打印一下console.log(a);你就会恍然大悟

phpcn_u1582

你把对象 b 当做 a 的属性,就会先调用对象btoString()方法。

var b={key:'b'};
b.toString(); // '[object Object]'

所以,

a[b] = 123;
// 即为
a['[object Object]'] = 123;
// 同理,下面一步赋值操作 c 也会先转换,然后再次更新属性 '[object Object]'对应的值
a['[object Object]'] = 456;
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage