美文网首页让前端飞
chrome控制台console.log无法时实打印引用类型值的

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

作者: 龙旗飘扬的舰队 | 来源:发表于2019-01-31 18:15 被阅读3次

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

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

    image

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

    image

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

    第一个

    image

    第二个

    image

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

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

    image

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

    image

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

    image image

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

    image image

    从结果上看,【点击...展开对象属性的值】控制台才会动态展示 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

    相关文章

      网友评论

        本文标题:chrome控制台console.log无法时实打印引用类型值的

        本文链接:https://www.haomeiwen.com/subject/syrlsqtx.html