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

查看:119
本文介绍了javascript - 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

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

解决方案

第一个例子中的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)

这篇关于javascript - js中全局变量和局部变量初始化问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆