chrome打印js对象属性时为什么有的是高亮色的有的是暗色?

1.问题? 

const foo  = {
    name:'kobe',
    age:18,
}


console.log(Object.prototype)
console.log(foo)

使用console打印一段代码时,我们发现,有的对象属性时高亮色,比如foo的age属性和name属性;

有些对象属性时暗色,比如Object.prototype的constructor属性、hasOwnProperty属性;

 

 

 

2.原因:

高亮色是可遍历的,数据描述符的enumable是true的;

浅色是不可以遍历的,enumable为fasel,在node中,不可遍历的属性时不会打印的,但是chrome可能为了我们调试代码方便,不可遍历的属性也使用暗色显示出来了。

 

 我们也可通过对象的proprotyIsEnumable()方法验证。

 

 

 

参考:

https://segmentfault.com/q/1010000017903420

 

posted @ 2022-06-11 12:19  Eric-Shen  阅读(368)  评论(0编辑  收藏  举报