[javascript] 变量提升

前端之家收集整理的这篇文章主要介绍了[javascript] 变量提升前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

摘自廖雪峰网站

JavaScript的函数定义有个特点,它会先扫描整个函数体的语句,把所有申明的变量“提升”到函数顶部

'use strict';

function foo() {
    var x = Hello,' + y;
    console.log(x);
    var y = Bob;
}

foo();

 

虽然是strict模式,但语句var x = 'Hello,' + y;并不报错,原因是变量y在稍后申明了。但是console.log显示Hello,undefined,说明变量y的值为undefined。这正是因为JavaScript引擎自动提升了变量y的声明,但不会提升变量y的赋值

对于上述foo()函数,JavaScript引擎看到的代码相当于:

function foo() {
    var y; // 提升变量y的申明,此时y为undefined
     y;
    console.log(x);
    y = ;
}

由于JavaScript的这一怪异的“特性”,我们在函数内部定义变量时,请严格遵守“在函数内部首先申明所有变量”这一规则。最常见的做法是用一个var申明函数内部用到的所有变量:

var
        x = 1, x初始化为1
        y = x +  y初始化为2
        z,i;  z和i为undefined
     其他语句:
    for (i=0; i<100; i++) {
        ...
    }
}

 

猜你在找的JavaScript相关文章