JS的全局变量和局部变量分析

1、Javascript在执行前会对整个脚本文件的声明部分做完整分析(包括局部变量),从而确定变量的作用域,但是不能对变量定义做提前解析。

解释:js执行之前只会对变量的声明做分析,确定变量的作用域。

2、方法内使用var定义变量是局部变量,不适用var定义变量是全局变量。

3、方法外:var name = 'muzidigbig';//显示声明

       name = 'muzidigbig';//隐式声明(为全局变量的一个属性)

例子:

1、程序的运行结果为:100  10  100

 var a = 10;
 function test(){
     a = 100;
     console.log(a);
     console.log(this.a);
     var a;
     console.log(a);
 }
 test();
解释:由于第6行声明了局部变量a,所以函数内部的a都指向已经声明的局部变量,所以第4行输出100。
    第5行输出this.a,我们都知道,函数内部的this指针指向的是函数的调用者,在这里函数test被全局对象调用,
    所以this指针指向全局对象(这里即window),所以this.a = window.a,一开始生命了全局变量a=10,所以第5行输出结果为10。
    第7行输出结果为100,因为局部变量a在第3行已经被赋值了100,所以直接输出局部变量a的值。

2、程序的运行结果为:undefined  10

  var a = 100;
  function test(){
    console.log(a);
    var a = 10;
    console.log(a);
  }
  test();

  在这个函数中,执行第3行前,可以认为已经声明了变量a,但是并没有定义(这里即赋值),所以第3行输出结果为undefined,执行第4行a =10后,变量a的值就为10,所以第5行输出结果为10。

3、程序的运行结果为:100  10  10

  var a = 100;
  function test(){
    console.log(a);
    a = 10;
    console.log(a);
  }
  test();
  console.log(a);

扫描二维码关注公众号,回复: 5661900 查看本文章

  a=10声明了一个全局变量,所以第3行的a应该输出全局变量的值,而在函数执行之前已经声明过一个全局变量并赋值100,所以这里第上输出100。第4行给全局变量a 重新赋值10,所以全局变量a的值变成10,所以第5行输出10。而在函数test外部,第8行输出全局变量a的值,因为全局变量被重新赋值为10,所以输出结果即为10。








猜你喜欢

转载自www.cnblogs.com/lp0636/p/10598242.html