js中定义一个变量可以加关键词var也可以不加,规则是这样的:
1. 在全局范围内用不用var都可以,变量都是全局的
2. 在局部范围内比如函数中,用不用var是不一样的,用var定义出来的是局部变量,不用var定义出来的是全局变量。
总结出来就是这样的:不用var定义出来的是全局变量,用var在全局范围内定义出来的也是全局变量,但是用var在局部范围内定义出来的是局部变量。
同时还有一个要注意,js在执行之前也是会进行语法分析的,比如下面的这个例子:
var i = 0;
alert(i);
function test() {
alert(i);
var i = 1;
alert(i);
}
test();
一般可能会认为第二个alert应该是0,但实际上这个却是undefined,因为在使用i之前,程序认为本函数内要定义一个局部变量i(不会认 为是全局变量i),但是局部变量i还未进行初始化,因此第二个alert会是undefined。总结出来是这样的,用var和function进行定 义,程序是会进行预处理的。比如:
test();
function test() {
alert(“good”);
}
一般会认为最开始使用不了test方法的,但是程序会先定义test方法的。
都不记得是什么时候看的JScript的语法教程了,里面说在声明变量时忽略var关键字是完全合法的。当时也因为觉得JavaScript是loosely-typed的语言,所以var可能真的就是个摆设。但是事实常常又证明想当然的结果是不可靠的 。
看看下面这几个例子的结果就知道问题了:
No.1
<script language="javascript">
var var00 = 0;
document.write(var00 + '<br>');
var var01 = 1;
function foo()
{
document.write(var01);
var var01 = 1;
}
foo();
</script>
No.2
<script language="javascript">
var00 = 0;
document.write(var00 + '<br>');
var01 = 1;
function foo()
{
document.write(var01);
var01 = 1;
}
foo();
</script>
No.3
<script language="javascript">
var00 = 0;
document.write(var00 + '<br>');
var01 = 1;
function foo()
{
document.write(var01);
var var01 = 1;
}
foo();
</script>
这三个例子的执行结果分别是:
Results#region Results
No.1
0
undefined
No.2
0
1
No.3
0
undefined
#endregion
原来JavaScript的变量也是有作用域的,只是它非常的笼统,就分为全局变量和函数变量。在第二个例子中得到0和1,是因为所有的变量都是全局变 量,而且那个语句块一共就定义了两个变量。而第一个第三的函数外全局变量,确实说明var关键字有没有都没有关系。而函数内的var关键字就很关键了,它 说明第二个var01是函数内的变量,所以在初始化var01前输出自然就是'undefined'了。
那么函数里面是不是就屏蔽掉了全局的var01了呢?我们知道在C/C++可以使用::去访问全局变量,那么JavaScript可不可以呢?这里其实我 们只要明白了全局变量到底是什么东西,就好弄了。原来全局变量都是动态添加到Window对象的实例window上的属性而以,所以我们只要在函数内 用:document.write(window.var01);就可以取到其值1了。同时在这个上下文中,function内的this也是指向的 window实例,我们也可以把引用写成:this.var01。
By the way, 重看JScript教程时,它说变量只能是[a-zA-Z_]+[a-zA-Z0-9_]*格式,可是'$'却也可以作为变量名字符 ,而且还可以用在开头,比如:$1234,更甚至于:$$$ 也是合法的变量名,faint。