Why Is Chrome Showing A Value As Being Removed From An Array Before It Has Been?
Solution 1:
In Chrome console.log
is "delayed"; in this case to the end of the Program I believe.
That is, in Chrome, console.log
does not stringify the input object immediately but rather performs the stringification "some time later" (after which the object has been modified in this case) but before it actually displays the result,
console.log(JSON.stringify(list))
would show the expected result.
This was reported as a bug as far back as Chrome 5 (the bug-fix target is Mstone-22, so not Chrome 20/21?) and a fix has been added to the webkit base:
As of today, dumping an object (array) into console will result in objects' properties being read upon console object expansion (i.e. lazily). This means that dumping the same object while mutating it will be hard to debug using the console.
This change starts generating abbreviated previews for objects / arrays at the moment of their logging and passes this information along into the front-end. This only happens when the front-end is already opened, it only works for console.log(), not live console interaction.
Post a Comment for "Why Is Chrome Showing A Value As Being Removed From An Array Before It Has Been?"