变量的作用域

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>

结果:

0

undefined

No.2

<script language="javascript">

var00 = 0;

document.write(var00 + '<br>');

var01 = 1; function foo() {    

document.write(var01);    

var01 = 1;

} foo();

</script>

结果:

0

1

 No.3

<script language="javascript">

var00 = 0;

document.write(var00 + '<br>');

var01 = 1;

function foo() {    

document.write(var01);    

var var01 = 1;

} foo();

</script>

结果:

0

undefined

     原来JavaScript的变量也是有作用域的,只是它非常的笼统,就分为全局变量和函数变量。在第二个例子中得到0和1,是因为所有的变量都是全局变量,而且那个语句块一共就定义了两个变量。而第一个第三的函数外全局变量,确实说明var关键字有没有都没有关系。而函数内的var关键字就很关键了,它说明第二个var01是函数内的变量,所以在初始化var01前输出自然就是'undefined'了。
     那么函数里面是不是就屏蔽掉了全局的var01了呢?我们知道在C/C++可以使用::去访问全局变量,那么JavaScript可不可以呢?这里其实我们只要明白了全局变量到底是什么东西,就好弄了。原来全局变量都是动态添加到Window对象的实例window上的属性而以,所以我们只要在函数内用:document.write(window.var01);就可以取到其值1了。同时在这个上下文中,function内的this也是指向的window实例,我们也可以把引用写成:this.var01。

原文地址:https://www.cnblogs.com/leejersey/p/2393299.html