函数声明优于变量声明。我们知道在代码逐行执行前,函数声明和变量声明会提前进行,而函数声明又会优于变量声明,这里的优于可以理解为晚于变量声明后,如果函数名和变量名相同,函数声明就能覆盖变量声明。所以以下代码将函数声明和变量声明调换顺序还是一样结果
console.log(typeof fn);
function fn() {};
var fn;
答案:function
同一个标示符,先后用var和function声明它。最后它是什么呢?
var a; // 声明一个变量,标识符为afunction a() { // 声明一个函数,标示符也为a
}
alert(typeof a);
显示的是“function”,即function的优先级高于var。
有人觉得这是代码顺序执行的原因,即a被后执行的funcion覆盖了。好,将它们调换下。
function a() {
}
var a;
alert(typeof a);
结果仍然显示的是“function”而非“undefined”。即函数声明优先于变量声明。
我们把代码稍作修改,声明a时同时赋值。
function a() {
}
var a = 1; // 注意此处
alert(typeof a);
这时显示的是“number”却不是“function”了,这相当于
function a() {
}
var a;
a = 1; // 注意此处
alert(typeof a);
即把“var a = 1”拆分为两步。 a被重新赋值了,自然是最后的那个值。
~function () {
alert(a);
a();
var a = function () {
console.log(1);
}
function a() {
console.log(2);
}
alert(a)
a();
var c = d = a;
}();
alert(d);
alert(c);
实际上代码是这么跑的
~function () {
//hoisting
function a() {
console.log(2);
}
var a;
alert(a);
a();
a = function () {
console.log(1);
}
alert(a)
a();
d = a;
var c = d;
}();
alert(d);
alert(c);
原因:
var c = d = a;
从右向左执行,
d=a
,d没有使用var声明,是一个全局变量,方法外部可访问。 ps:中间的那个是全局变量。
6、报错,原因:c是函数内部的变量,外部访问不到的,外部变量c是undefined。
其它的就不一一解释原因了,本质就是变量提升和函数声明提升的问题。