js中全局变量和局部变量初始化问题

var age=100;
function box(){
    age++;
}
box();//age=101
box();//age=102

function box(){
var age=100;
age++;
return age;
 }

box();//age=101;
box();//age=101

为什么全局变量初始化过后,调用函数会累加?而局部变量每次调用变量都会初始化一次?
他们这个过程中发生了什么呢?是因为储存方式,内存的原因??

阅读 5.5k
2 个回答

第一个例子中的age在全局中声明,即全局变量,所以age一直存在,每次调用box()时会根据作用域链找到全局作用域中的age,所以会一直累加;
第二个例子中的age在box中声明,即局部变量,agebox调用时创建,调用完box()即被销毁,下次再调用box时会创建一个新的age,调用完再销毁,所以无法实现累加,如果想实现的话,可以使用闭包,创建闭包之后对私有变量处于引用状态,不会销毁,存在内存中,可以实现累加。

function box(){
    var age=100;
    return function() {
        age++;
        console.log(age);
    }
}
var b = box();
b(); // 101
b(); // 102

学习Javascript闭包(Closure)

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题