This is the second post in the series of posts explaining some fascinating features and caveats of javascript. "Function Declaration Hoisting" the name itself is intimidating ...!!!
Lets understand it with an example. What do you think will be the output of the below code snippet?
//Code Snippet 1
var isTrue=true;
if(isTrue) {
function myFunc(){
alert("Hello True");
}
}
else {
function myFunc(){
alert("Hello False");
}
}
myFunc();
The answer is "Hello False".
When javascript interpreter starts scanning the javascript, it scans the function declaration first.
What it means that, we can write some code like below and it works fine.
//Code Snippet 2
myFunction();
function myFunction(){
alert("Hello World");
}
Now we can see that we have called the function before implementing it ,still it works due to this feature called "Function Declaration Hoisting".Where javascript scans and interprets all the function declaration in document first before interpreting any of the statements.
If this feature would not have been there "Code Snippet 2" would fail because interpreter would have tried to execute statement "myFunction();" before knowing about function "myFunction()".
"Code Snippet 1" does not work properly because in first scan interpreter reads both the implementations of the function "myFunc()" without caring if the variable "isTrue" evaluates to "true" or "false". Now as i discussed in my previous post javascript does not support function overloading ,hence for javascript after first scan there is only one function named "myFunc()' with the implementation in the "else part as it was the last one to appear in the execution".So whatever be the value of the variable "isTrue", output will always be "Hello False".
Lets understand it with an example. What do you think will be the output of the below code snippet?
//Code Snippet 1
var isTrue=true;
if(isTrue) {
function myFunc(){
alert("Hello True");
}
}
else {
function myFunc(){
alert("Hello False");
}
}
myFunc();
The answer is "Hello False".
When javascript interpreter starts scanning the javascript, it scans the function declaration first.
What it means that, we can write some code like below and it works fine.
//Code Snippet 2
myFunction();
function myFunction(){
alert("Hello World");
}
Now we can see that we have called the function before implementing it ,still it works due to this feature called "Function Declaration Hoisting".Where javascript scans and interprets all the function declaration in document first before interpreting any of the statements.
If this feature would not have been there "Code Snippet 2" would fail because interpreter would have tried to execute statement "myFunction();" before knowing about function "myFunction()".
"Code Snippet 1" does not work properly because in first scan interpreter reads both the implementations of the function "myFunc()" without caring if the variable "isTrue" evaluates to "true" or "false". Now as i discussed in my previous post javascript does not support function overloading ,hence for javascript after first scan there is only one function named "myFunc()' with the implementation in the "else part as it was the last one to appear in the execution".So whatever be the value of the variable "isTrue", output will always be "Hello False".