console.log(a());
function a(){
console.log("hello");
}
From above code, i will expect "hello"
(and some undefined
s) to be logged on console. But firebug gives
ReferenceError: a is not defined
So firebug does not do hoisting?
console.log(a());
function a(){
console.log("hello");
}
From above code, i will expect "hello"
(and some undefined
s) to be logged on console. But firebug gives
ReferenceError: a is not defined
So firebug does not do hoisting?
The reason for the issue is that
functions do not hoist when declared inside a child block.
by MDN (Much covered here is not standard ECMAScript).
Compare the following snippets:
alert(c());
function c(){return 42;}
and
{
alert(c());
function c(){return 42;}
}
The first one will alert 42, whereas the second one will throw ReferenceError
.
And here is the code that gets executed when you are playing with Firebug:
data;
with(_FirebugCommandLine){ // >> block begins
console.log(a());
function a(){
console.log("hello");
}
} // << block ends
Update
The behavior observed seems to be a glitch in Firefox javascript engine because it is not observed in chrome and IE9, see this fiddle.