本文主要是介绍JavaScript的变量申明提前,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
变量提升
JavaScript的函数定义有个特点,它会先扫描整个函数体的语句,把所有申明的变量“提升”到函数顶部:
只是将变量的申明提前,而不提前变量的值和函数的值
'use strict';function foo() {var x = 'Hello, ' + y;alert(x);var y = 'Bob';
}foo();
虽然是strict模式,但语句var x = 'Hello, ' + y;
并不报错,原因是变量y
在稍后申明了。但是alert
显示Hello, undefined
,说明变量y
的值为undefined
。这正是因为JavaScript引擎自动提升了变量y
的声明,但不会提升变量y
的赋值。
对于上述foo()
函数,JavaScript引擎看到的代码相当于:
function foo() {var y; // 提升变量y的申明var x = 'Hello, ' + y;alert(x);y = 'Bob';
}
由于JavaScript的这一怪异的“特性”,我们在函数内部定义变量时,请严格遵守“在函数内部首先申明所有变量”这一规则。最常见的做法是用一个var
申明函数内部用到的所有变量:
function foo() {varx = 1, // x初始化为1y = x + 1, // y初始化为2z, i; // z和i为undefined// 其他语句:for (i=0; i<100; i++) {...}
}
这篇关于JavaScript的变量申明提前的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!