45fan.com - 路饭网

搜索: 您的位置主页 > 电脑频道 > 编程代码 > 阅读资讯:JavaScript的全局变量与局部变量的关系和联系

JavaScript的全局变量与局部变量的关系和联系

2016-08-14 06:23:20 来源:www.45fan.com 【

JavaScript的全局变量与局部变量的关系和联系

一、JavaScript scope 的划分标准是function函数块,不是以 if、while、for来划分的

<script>
function f1(){
  alert("before for scope:"+i);  
 //i未赋值(并不是没有声明!使用未声明变量或函数会导致致命错误从而中断脚本执行)
 //此时i值为undefined
  for(var i=0; i<3;i++){
    alert("in for scope:"+i);}
 //i的值是0,1,2 
  alert(“after for scope:”+1);
 //i的值是3,此时已经在for scope之外,但i的值仍然保留为3
  while(true){
    var j=1;
    break;}
  alert(j);
 //j的值是1,此时已经在while scope之外,但j的值仍然保留为1
  if(true){
   var k=1;
  }
  alert(k);
 //k的值为1,此时已经在if scope之外,但k的值仍保留为1
}
f1();
//此时在函数块外调用函数,再次输出存在于f1这个function scope里的i j k变量
alert(i);
//error!!!原因是这里的i未声明(不是未赋值,区别f1的第一行输出),脚本错误,程序结束!
alert(j);  
//未执行
alert(k);
//未执行
</script>

二、JavaScript在执行之前会对整个脚本文件进行预编译(对脚本文件的声明部分做分析,包括局部变量部分),从而确定实变量的作用域。举个例子在下边:

<script>
  var x=1;
  function f2(){
  alert(x);
  //x的值为undefined!这个x并不是全局变量,因为在function scope已经又声明了一个重名的局部变量,所以全局变量的参数a被覆盖了。
  说明了JavaScript在执行前会进行预编译,函数体内的x就被指向局部变量,而不是全局变量。此时x只有声明,没有赋值,所以为undefined
  x=3;
  alert(x);
  //x值为3.但还是局部变量
  var x;
  //局部变量x在这里声明
  alert(x);
  //值为3
  }
  f2();
  alert(x);
  //x值为1,并不是在function scope内,x的值为全局变量的值。
</script>

三、当全局变量跟局部变量重名时,局部变量的scope会覆盖掉全局变量的scope,当离开局部变量的scope后,又重回到全局变量的scope,而当全局变量遇上局部变量时,

怎样使用全局变量呢?用window.globalVariableName。

<script>
  var a=1;
  function f3(){
    alert(window.a);
 //a位1,这里的a是全局变量
    var a=2;
    alert(a);
   }
  f3();
  alert(a);
</script>

以上这篇浅谈JavaScript的全局变量与局部变量就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持路饭。


本文地址:http://www.45fan.com/bcdm/62523.html
Tags: JavaScript 浅谈 全局
编辑:路饭网
推广内容
推荐阅读
热门推荐
推荐文章
关于我们 | 联系我们 | 友情链接 | 网站地图 | Sitemap | App | 返回顶部