Bitesize Bugs

Accidental Global Variables in JavaScript

Omitting the “var” keyword when declaring a variable in JavaScript will scope it to the global namespace.

Thus, the variable is no longer bound to the scope of the parent function or object instance, but accessibile to every other script through the global “window” object.

Example

SeeĀ https://gist.github.com/1092039

Avoid accidentally creating global variables by always declaring them with ‘var’.

This problem gets especially frustrating when expecting variables to be private, bound to instances of an object. You soon realize that your instances’ internal states change unexpectedly.


 

 

 

 

 

Advertisements

Filed under: JavaScript, , , , , , , ,

So what’s it about?

Bitesize Bugs is a collection of short articles that expose pesky bugs in front-end web technologies like JavaScript, CSS, HTML and browser behaviors gone bad.