JavaScript没有块级作用域

有些知识,不经常去碰,就会遗忘,在学习的过程中,经常做笔记,没事的时候回头看看也是种享受.

JavaScript没有块级作用域经常会造成理解上的困惑。在其他语言中,由花括号封闭的代码块都有自己的作用域(如果用ECMAScript的话来讲,就是它们自己的执行环境),因而支持根据条件来定义变量。

例如,如下的代码在JavaScript中并不会得到想象中的结果:

  <script type="text/javascript">
   //javascript没有块级作用域
      if(true){
    	  var color="blue";
      }
     alert(color);//弹出的值是 blue
      
     for(var i=0;i<10;i++){
     }
     alert(i);//弹出的值是10
     
  </script>

在JavaScript中:

 (1) if语句中的变量声明会将变量添加到当前的 执行环境(在这里是全局环境)中,如果再函数中,则添加到函数的局部环境中.

 (2) for语句创建的变量i,即使在for循环执行结束后,也依旧会存在于循环外部的执行环境中,如果再函数中,则添加到函数的局部环境中.


1、声明变量

   使用var声明的变量会自动添加到最接近的环境中。在函数内部,最接近的环境就是函数的局部环境;在with语句中,最接近的环境就是函数环境。如果初始化变量时没有使用var声明,该变量会自动添加到全局环境.

   <script type="text/javascript">
        function add(num1,num2){
         	var sum=num1+num2;
         	return sum;
        }
        var result=add(10,20);    //30
        alert(result);//30
        alert(sum);  //由于sum不是有效的变量,因此会导致错误
   </script>

浏览器访问这个页面时,会弹出30,而后面的alert(sum)没有反应,F12打开浏览器控制台可以发现JS报错了,sum没有定义.


如果去掉sum去掉var的声明,则不会报错,因为改sum已添加到全局环境中了.



posted on 2016-10-22 11:25  吴一达  阅读(469)  评论(0编辑  收藏  举报

导航