chrome控制台console.log无法时实打印引用类型值的bug

在js脚本中,使用console.log打印一个大型的对象(像 vm (vue实例),或者 window 对象),然后再设置延迟改变该对象的的某个属性(假设属性名为 ppp )的值,会发现个有趣的现象:

如果是 window,假设执行如下脚本

会在控制台打印出如下输出:

首先,马上点击展开第一个输出值,10s后点击展开第二个输出值,会发现两个值分别为

第一个

第二个

从结果上看,【点击展开对象】时,控制台才会动态展示window对象的属性值。第一次点击,ppp的值仍然是666,10s之后再点击就变为了20000

如果是 vm 对象,也有问题,只是略有不同,如下:

首先,打印出数据后,第一时间点击并展开这两个对象

等待5s后,【点击 ... 展开第一个对象属性ppp的值】,展开前后分别如下图

等待10s后,【点击 ... 展开第二个对象属性ppp的值】,展开前后分别如下图

从结果上看,【点击...展开对象属性的值】控制台才会动态展示 vm 对象的属性ppp的值


所以可以确定,这个是 chrome 内核中 console.log 功能上的一个bug,而且没有修复。实际上,这个bug早在2012年就已经被提出,不过至今没有正式修复。目前已知,火狐浏览器上,并没有这个问题。

目前并没有特别好的解决办法,如果强制 string 化,对某些 dom 类对象是有问题的,所以只能尽量不要打印过于复杂的对象,或者仅打印必要的对象属性

这个bug目前的状态如下:

Webkit(http://trac.webkit.org/changeset/125174)2012年8月9日两年半后实施了一个修复程序,但似乎还没有将其添加到Chrome中。

参考文档:

WebKit Bugzilla

javascript – Google Chrome console.log()与对象和数组不一致

Google Chrome console.log() inconsistency with objects and arrays

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值