函数声明优于变量声明是指函数声明可覆盖变量声明

函数声明优于变量声明。我们知道在代码逐行执行前,函数声明和变量声明会提前进行,而函数声明又会优于变量声明,这里的优于可以理解为晚于变量声明后,如果函数名和变量名相同,函数声明就能覆盖变量声明。所以以下代码将函数声明和变量声明调换顺序还是一样结果

console.log(typeof fn);
function fn() {};
var fn;
答案:function


同一个标示符,先后用var和function声明它。最后它是什么呢?

var a; // 声明一个变量,标识符为a
function 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。
其它的就不一一解释原因了,本质就是变量提升和函数声明提升的问题。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值