this post was submitted on 29 Dec 2023
229 points (80.1% liked)
Programmer Humor
32562 readers
455 users here now
Post funny things about programming here! (Or just rant about your favourite programming language.)
Rules:
- Posts must be relevant to programming, programmers, or computer science.
- No NSFW content.
- Jokes must be in good taste. No hate speech, bigotry, etc.
founded 5 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
Wait...... you can use a variable before you declare it?
Classic javascript doing javascript things (this is why they introduced let and const)
Kind of. With hoisting, the compiler/interpreter will find variable declarations and execute them before executing the rest of the code. Hoisting leaves the variables as undefined until the code assigning the value to the variable is executed. Hoisting does not initialize the variables.
For example:
console.log(foo);
var foo;
//Expected output: console logs 'null'
foo = 'bar';
console.log(foo);
var foo;
//Expected output: console logs 'bar'
console.log(foo === undefined);
var foo;
//Expected output: console logs 'true'
This means you can essentially write your code with variable declarations at the end, but it will still be executed as though the declarations were at the beginning. Your initializations and value assignments will still be executed as normal.
This is a feature that you should probably avoid because I honestly cannot think of any good use case for it that won't end up causing confusion, but it is important to understand that every variable within your scope will be declared at the beginning of execution regardless of where it is written within your code.
Should log
hoisted
and thenundefined
, showing that you've assigned to the later-declaredvar a
which was hoisted vs the external globala
.