javascript的特性之一:声明提前

var scope = "global";
function f() {
    console.log(scope); // 输出“undefind”,而不是“global”
    var scope = "local"; // 变量在这里赋初始值,但变量本身在函数体内任何地方均是有定义的
    console.log(scope); // 输出“local”
}
你可能会误以为函数中的第一行会输出“global”,因为代码还没有执行到var语句声明局部变量的地方。其实不然,由于函数作用域的特性,局部变量在整个函数体始终是有定义的,也就是说,在函数体内局部变量遮盖了同名全局变量。尽管如此,只有在程序执行到var语句的时候,局部变量才会被真正赋值。因此,上述过程等价于:将函数内的变量声明“提前”至函数体顶部,同时变量初始化留在原来的位置:
function f() {
    var scope;          // 在函数顶部声明了局部变量
    console.log(scope); // 变量存在,但其值是“undefined”
    var scope = "local"; // 这里将其初始化并赋值
    console.log(scope); // 这里它具有了我们所期望的值
}

发布了13 篇原创文章 · 获赞 20 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/gufudhn/article/details/103990562