简单来说,可以理解为用var修饰的变量为局部变量,没用var修饰的为全局变量。不过有些问题我们得留意。
首先,当一个变量没被var修饰时,js会在当前的作用域的上下文查找当前变量是否有被定义。如果没有则会生成一个全局变量,即document下的变量,如果有,则不生成。
这将导致一个问题。
eg:
var test = 1;
function foo()
{
document.write(test);
test=2;
}
写入的值是1,原因是test的作用域包括foo()函数,函数foo可以直接访问,此时如果函数外再访问test,值将变为2.
如果是下面这种情况呢?
var test = 1;
function foo()
{
document.write(test);
var test =2;
}
foo();
答案还是1么?不是,此时答案变为了undefined!为啥呢?当js执行到document.write()时,他会检测上下文,当检测到var test=2时,说明test是局部变量,当然他也就不会去函数外取值了,但此时js只是知道不需要为test申请内存,写入时test的值还未初始化呢,当然就是undefined了!
当然,不要被搞迷糊了,如果像下面这样可就是bug了!
<pre name="code" class="javascript">function foo()
{
document.write(test);
test=2;
}
foo();
此时由于js上下文都检测不到test的定义,程序会运行不了的。咦!你刚不是说检测不到或自己申请空间的么?注意啦!这里test只是个形参,js不会为形参自动生成实例的!