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

Slow Android emulator

I have a 2.67 GHz Celeron processor, 1.21 GB of RAM on a x86 Windows XP Professional machine. My understanding is that the Android emulator should start fairly quickly on such a machine, but for me it does not. I have followed all instructions in setting up the IDE, SDKs, JDKs and such and have had some success in staring the emulator quickly but is very particulary. How can I, if possible, fix this problem?

CCNA 3 Final Exam => latest version

1 . Which security protocol or measure would provide the greatest protection for a wireless LAN? WPA2 cloaking SSIDs shared WEP key MAC address filtering   2 . Refer to the exhibit. All trunk links are operational and all VLANs are allowed on all trunk links. An ARP request is sent by computer 5. Which device or devices will receive this message? only computer 4 computer 3 and RTR-A computer 4 and RTR-A computer 1, computer 2, computer 4, and RTR-A computer 1, computer 2, computer 3, computer 4, and RTR-A all of the computers and the router   3 . Refer to the exhibit. Hosts A and B, connected to hub HB1, attempt to transmit a frame at the same time but a collision occurs. Which hosts will receive the collision jamming signal? only hosts A and B only hosts A, B, and C only hosts A, B, C, and D only hosts A, B, C, and E   4 . Refer to the exhibit. Router RA receives a packet with a source address of 192.168.1.65 and a destination address of 192.168.1.161...