传递控制台.log对象在使用两个参数时返回不同 - 为什么



我一直在使用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

最新更新