Skip to main content

Javascript Funky array mishap





function a() {

var b = ["b"];

console.log(b);

//console.log(b.slice());

b = b.push("bb");

}

a();







In a "perfect" world you would think that the console.log would show ["b"] , but wildly enough it shows ["b", "bb"] even though "bb" isn't pushed on until afterword . *wtf*





If you do console.log(b.slice()); Then you will get the desired result of ["b"] . What gives? What's the reason behind this complication? I just want to understand this better so I can better avoid it from happening.





*note I hit on this same point in a recent question of mine, but this is a much more concise example. @RightSaidFred has led me to this point and has been a HUGE help so far (big thanks).





** EDIT **





Runnable example on JSFiddle





** POST-ANSWER **





This is all due to a problem where console.log messes up sometimes. Thanks to everyone for all the help in figuring this out.



Source: Tips4all

Comments

  1. This is a known problem with console.log.

    Instead of turning the parameter into a string when you call the method, the parameter is stored and turned into a string when it's displayed in the UI. As nothing happens in the UI while the function is running, you will see the state of the object as it is when you exit the function.

    ReplyDelete
  2. I'm assuming this has to do with the way that console.log() works although you're doing something a little funky when you say:

    b = b.push("bb");


    you should be able to just say

    b.push("bb");

    ReplyDelete
  3. Confirmation (if needed) of Guffa's answer :

    function a() {
    var b = ["b"];
    console.log (b);
    console.log (' ' + b);
    console.log (b);
    console.log (b.toString ());
    console.log (b);
    b = b.push("bb");
    console.log (b);
    }
    a();


    Chrome outputs :

    ["b", "bb"]
    b
    ["b", "bb"]
    b
    ["b", "bb"]
    2


    Note how every log referencing the object shows the "anomolous" result and each one which requires the evaluation of an expression does not. Note also the final log which shows that b is set to the value value 2, since the value returned by push is the new length of the array.

    So, to avoid this issue ensure that each log parameter involves the evaluation of an expression.

    ReplyDelete
  4. I think it's a bug on the google chrome dev tools

    ReplyDelete

Post a Comment

Popular posts from this blog

[韓日関係] 首相含む大幅な内閣改造の可能性…早ければ来月10日ごろ=韓国

div not scrolling properly with slimScroll plugin

I am using the slimScroll plugin for jQuery by Piotr Rochala Which is a great plugin for nice scrollbars on most browsers but I am stuck because I am using it for a chat box and whenever the user appends new text to the boxit does scroll using the .scrollTop() method however the plugin's scrollbar doesnt scroll with it and when the user wants to look though the chat history it will start scrolling from near the top. I have made a quick demo of my situation http://jsfiddle.net/DY9CT/2/ Does anyone know how to solve this problem?

Why does this javascript based printing cause Safari to refresh the page?

The page I am working on has a javascript function executed to print parts of the page. For some reason, printing in Safari, causes the window to somehow update. I say somehow, because it does not really refresh as in reload the page, but rather it starts the "rendering" of the page from start, i.e. scroll to top, flash animations start from 0, and so forth. The effect is reproduced by this fiddle: http://jsfiddle.net/fYmnB/ Clicking the print button and finishing or cancelling a print in Safari causes the screen to "go white" for a sec, which in my real website manifests itself as something "like" a reload. While running print button with, let's say, Firefox, just opens and closes the print dialogue without affecting the fiddle page in any way. Is there something with my way of calling the browsers print method that causes this, or how can it be explained - and preferably, avoided? P.S.: On my real site the same occurs with Chrome. In the ex