我一直在使用console.log来记录一个对象,并注意到它不会返回对象的值,除非该对象是console.log中自己的参数。为什么会这样?
const obj = {animal: "Dog"};
console.log("obj:", obj); //returns { animal: 'Dog' }
console.log("obj: " + obj); //returns obj: [object Object]
console.log(`obj: ${obj}`); //returns obj: [object Object]
当您显式连接两者时,obj 将转换为其字符串表示形式,又名 obj.toString()
,这将[object Object]
。
为了使事情更有趣,我们可以检查console.log()
是如何工作的,例如在 Node 中。它使用util.format()
来格式化输出。如果它检测到它不是一个简单的字符串,它会inspect
对象并决定进一步的步骤。请参阅 https://github.com/nodejs/node/blob/master/lib/util.js#L169