js 中变量优先级的问题?

在js中函数声明的优先级不是最高的吗?为什么输出的反而是变量申明的函数?
图片描述

阅读 5.1k
5 个回答

上面的函数声明和变量声明提升之后的执行情况如下:

var aa;
function aa(){
    alert(22222222);
};
aa = function(){
    console.log(11111);
};

这样的话执行 aa(); 的话当然就是 11111
跟优先级没有关系呀,只跟执行顺序有关,前面的被后面覆盖掉啦。我的理解是这样的,如有错误,望指正

的确函数声明的优先级是最高的,使用 function 关键字声明,JS 解释器会将其提至作用域最顶端,也就是说题主的写法相当于是如下:

var aa = function() {alert("2222222")};
var aa = function() {console.log("111111")};
是的,函数声明提升的优先级比变量声明的优先级高,但是,变量提升的是var aa,后面的赋值并没有被提升,而函数声明function aa(){}会整个函数提升,此时编译时aa是function aa(){alert('2222')}!
然后,进行一行一行代码解析时,第一行其实是aa = function(){console.log('1111')},于是把aa改成function(){console.log('1111')},然后下面就没有代码可以解析了,因为函数声明已经提前解析了!所以最后aa的值就是function(){console.log('1111')}

@wangfulin 回答的很好啊,js预解析后,情况就是他说的那样,会先把所有变量的声明放前面,然后是函数声明,也就是:

var aa; //变量声明提前,这时候aa是undifined
function aa(){    //函数声明提前,相当于aa=function() {alert("2222222")};但是并没有执行,只是给aa赋值了。这时候打印aa,aa为函数
    alert(22222222);
};
aa = function(){    //函数表达式给aa赋值,aa = function() {console.log("111111")}; 这时候aa是另一个函数,然后执行,打印11111
    console.log(11111);
};

声明提前,赋值停留原地,所以,你在最上面可以发现 先声明的aa 其实是 function的声明,你在aa的 函数表达式的后面执行aa(),其实 aa已经被函数表达式的赋值 覆盖了,自然 执行 输出就是 console 而不是 alert

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题