聊一聊 JS 输出为 [object object] 是怎么回事?
今天在学习ES6中的 Symbol
数据类型时,在写demo时控制台输出为 Symbol[object object]
,当时有点疑惑,查阅了相关资料后搞清楚了其中的原因。
在解释之前,由于有些小伙伴可能还没有接触过ES6,所以先说一下上面用到的ES6的一些特性:
现在上那段输出 Symbol[object object]
的代码:
const obj = {
f() {
return "abc";
}
};
const sym = Symbol(obj);
console.log(sym); // Symbol[object object]
由于 obj
是一个对象,所以会调用 toString()
方法将其转换为字符串,对 toString
方法不太了解的小伙伴可以查看下面MDN的解释:
obj
是我们自定义的对象,而且 toString()
方法也没有被覆盖,所以会返回 [object object]
。
现在我们尝试覆盖 toString()
方法,如下面的代码所示:
// ES5写法
var obj = {
toString: function() {
return "abc";
}
};
// ES6写法
const obj = {
toString() {
return "abc";
}
};
const sym = Symbol(obj);
console.log(sym); // Symbol(abc)
当我们覆盖掉 toString()
方法之后,自定义对象 obj
在调用 toString()
方法的时候调用的就是我们自定义的 toString()
方法, 输出为 "abc"
。因此最终的结果为 Symbol(abc)
。
完,如有不恰当之处欢迎指正哦。