先来看一个例子:
var tmp = "hello javascript";
function f() {
console.log(tmp);
var tmp = "hello world";
}
f();
console.log(tmp);
上面代码最终运行结果如下:
undefined
hello javascript
是不是很诧异,按道理应该两次log都是”hello javascript”,这是因为变量提升了,在函数里声明的所有变量都被提升至函数体前面,上面函数f()相当于:
function f() {
var tmp
console.log(tmp);
tmp = "hello world";
}
所以第一次log会输出undefined。所以函数体内变量赋值或者初始化要放在最前面。
把函数f()修改下,重新运行。
function f() {
console.log(tmp);
tmp = "hello world";
}
运行结果为
hello javascript
hello world
因为 tmp = “hello world” 没有初始化,当在函数体内给一个变量赋值时不加 var 修饰符则自动升级该变量为全局变量,此时最后面的console.log(tmp)会输出hello world
本文通过具体示例解释了JavaScript中变量提升的概念,并展示了如何避免由于变量提升而导致的意料之外的行为。文章还探讨了在函数作用域内不使用var关键字给变量赋值时可能引发的问题。
281

被折叠的 条评论
为什么被折叠?



