javascript - 关于变量提升的问题
天蓬老师
天蓬老师 2017-04-11 13:00:43
[JavaScript讨论组]
var foo = 1;
function bar () {
    if (!foo) {
        var foo = 10;
    }
    console.log(foo);
}
bar();
var foo = 1;

为什么if里面的变量foo会提升到bar的顶端?if里面不是一个作用域吗?

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(5)
ringa_lee

这么说吧. javascript只有三种作用域:

  1. 全局作用域

  2. function 制造的作用域

  3. with 制造的作用域

PHP中文网

这个问题牵扯到作用域/作用域链JS变量声明提前
JS变量声明提前:变量声明会提前到对应作用域的最前面执行;
ES6中有块级作用域声明 let;
var foo = 10;其实是两个步骤var foo;foo=10;,并且var foo;变量声明会先于此作用域的其他代码执行;

这就是为什么下面这段代码

console.log(a);
var a=1;

js不报错,并打印出来的值是undefined

你问题中代码的执行顺序其实是

var foo = 1;
function bar () {
    var foo;
    if (!foo) {  //foo为undefined
        foo = 10;
    }
    console.log(foo);
}
bar();
var foo = 1;
高洛峰

js里只有函数是作用域,没有块级作用域。

PHP中文网

使用 let 声明的变量在这种情况才有块级作用域

高洛峰

bar如果没有 他会往上继续去找 直到找到最顶层。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号