码迷,mamicode.com
首页 > 编程语言 > 详细

javascript变量提升

时间:2016-02-28 15:17:49      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:

<script>
    function aa(){

        console.log("before", i);
        setTimeout(function () {
            console.log("setTimtout", i);
        });

        for(var i = 0; i<= 3; i++){
            console.log("for", i);
        }

        console.log("after", i);
    }

    aa();
</script>

结果:

before undefined

for 0

for 1

for 2

for 3

after 4

setTimtout 4

 

 分析:

变量i定义在for中,首次进入aa函数时,还没有执行for,所以i变量没有定义。当执行了for之后,setTimeout可以打印出i变量,说明i变量的作用域提升了。

javascript变量提升

标签:

原文地址:http://www.cnblogs.com/longcloud/p/5224751.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!