1foo(); 2var foo; 3function foo(){ 4 console.log(1); 5} 6foo = function(){ 7 console.log(2); 8}
参考答案:
答案是:1
函数声明和变量声明都会被提升,但是有一个值得注意的细节,那就是,函数会首先提升,然后才是变量!
根据 JavaScript 的变量和函数提升规则,上述代码在执行时会被解析成以下形式:
1function foo(){ 2 console.log(1); 3} 4 5var foo; // 变量声明被提升至顶部 6 7foo(); // 输出 1 8 9foo = function(){ 10 console.log(2); 11}
以下是代码的执行过程:
foo
的函数声明被提升到作用域的顶部。所以,在调用 foo()
之前,函数 foo
已经可用。2.然后,变量 foo
被声明,并且由于它已经被函数 foo
的定义所覆盖,因此这个变量声明没有改变函数 foo
的值。
接下来,函数 foo
被调用,输出结果为 1
。
最后,变量 foo
被重新赋值为一个新的函数表达式,该函数输出结果为 2
。
所以,最终输出结果为:
1
最近更新时间:2024-07-20