每一种语言都有变量的概念,变量是用来存储信息的一个元素。比如下面这个函数:
复制代码 代码如下:
function Student(name,age,from)
{
this.name = name;
this.age = age;
this.from = from;
this.ToString = function()
{
return "my information is name: "+this.name+",age : "+this.age+", from :" +this.from;
}
}
Student类有三个变量,分别为name(名字),age(年龄),from(籍贯),这三个变量构成了描述一个对象的信息。当然,这里还有一个方法用来返回Student的信息。
但是,我们是不是定义了一个变量,它就能一直存在着,并且还有可能在任何地方都能被访问和使用直到其被销毁?仔细想想,上面的需求是比较过分的,因为某些变量在某个功能实现后就不再利用了,但如果这个变量还存在的话,就占用了系统资源了,俗语曰:“站着茅坑不拉#$%”。
于是我们对变量的及时和按需求地销毁有一个探讨的话题了。
好,切入正题吧,就本人所接触过的来讲,js中支持如下几种类型的变量,分别为:局部变量、类变量、私有变量、实例变量、静态变量和全局变量。接下来我们就一一探讨研究下。
局部变量:
局部变量一般指在{}范围内有效变量,也就是语句块内有效的变量,如:
复制代码 代码如下:
function foo(flag)
{
var sum = 0;
if(flag == true)
{
var index;
for(index=0;index<10;index++)
{
sum +=index;
}
}
document.write("index is :"+index+"<br>");
return sum;
}
//document.write("sum is :" +sum+"<br>");
document.write("result is :"+foo(true)+"<br>");
复制代码 代码如下:
function foo(flag)
{
var sum = 0;
for(var index=0;index<10;index++)
{
sum +=index;
}
document.write("index is :"+index+"<br>");
return sum;
}
您将可以看见可以输出index值("index is :10"),这个是js和其他语言的不同地方,因为index是在for循环的{}外面定义的,因此其作用范围在foo()函数使用完毕后才销毁。
类变量:
类变量,实际上就是类的一个属性或字段或一个方法,该变量在该类的一个实例对象被销毁后自动销毁,比如我们开始时举的Student类。这个我们不多讨论,大家可以自己试一下。
私有变量:
私有变量,值得是某个类自己内部是用的一个属性,外部无法调用,其定义是用 var 来声明的。注意如果不用var 来声明,该变量将是全局变量(我们下面将会讨论),如:
复制代码 代码如下:
function Student(name,age,from)
{
this.name = FormatIt(name);
this.age = age;
this.from = from;
var origName = name;
var FormatIt = function(name)
{
return name.substr(0,5);
}
this.ToString = function()
{
return "my information is name: "+origName+",age : "+this.age+", from :" +this.from;
}
}
这里,我们分别定义了一个origName和FormatIt()两个私有变量(按面向对象的解释,应该用类的属性来称呼)。
我们把这种情况下的方法也成为变量,因为该情况下的变量是个function类型的变量,而function也属于Object类的继承类。在这种情形下,如果我们定义了 var zfp = new Student("3zfp",100,"ShenZhen")。但无法通过zfp.origName和zfp.FormatIt()方式来访问这两个变量的。
注意以下几点:
1、私有变量是不能用this来指示的。
2、私有方法类型的变量的调用必须是在该方法声明后。如我们将Student类改造如下:
复制代码 代码如下: