>  기사  >  웹 프론트엔드  >  Javascript 변수 유형 및 범위 예제에 대한 자세한 설명

Javascript 변수 유형 및 범위 예제에 대한 자세한 설명

伊谢尔伦
伊谢尔伦원래의
2017-07-18 09:59:291185검색

1. Javascript 변수의 범위는 메소드 블록에 따라 구분됩니다(즉, 함수에서 중괄호 {} 쌍으로 구분됩니다). 이는 함수 블록이며 for, while 및 if 블록은 범위 분할의 표준이 아닙니다. 다음 예를 볼 수 있습니다.


<script>
function test2(){
  alert ("before for scope:"+i);  // i未赋值(并不是未声明!使用未声明的变量或函数全抛出致命错误而中断脚本执行)
                          // 此时i的值是underfined
  for(var i=0;i<3;i++){
    alert("in for scope:"+i); // i的值是 0、1、2, 当i为3时跳出循环
  }
  alert("after for scope:"+i); // 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
}
test2();
//若在此时(function scope之外)再输出只存在于test2 这个function scope里的 i、j、k变量会发生神马效果呢?
alert(i); //error! 没错,是error,原因是变量i未声明(并不是未赋值,区分test2函数的第一行输出),导致脚本错误,程序到此结束!
alert("这行打印还会输出吗?"); //未执行
alert(j); //未执行
alert(k); //未执行
</script>

2. Javascript는 실행 전에 전체 스크립트 파일을 선언합니다. 실제 변수의 범위를 결정하려면 전체 분석(지역 변수 포함)을 수행하십시오. 그것을 이해하는 방법? 다음 예를 살펴보세요.


<script>
  var a =1;
  function test(){
    alert(a); //a为undefined! 这个a并不是全局变量,这是因为在function scope里已经声明了(函数体倒数第4行)一个重名的局部变量,
           //所以全局变量a被覆盖了,这说明了Javascript在执行前会对整个脚本文件的定义部分做完整分析,所以在函数test()执行前,
           //函数体中的变量a就被指向内部的局部变量.而不是指向外部的全局变量. 但这时a只有声明,还没赋值,所以输出undefined。
    a=4    
    alert(a); //a为4,没悬念了吧? 这里的a还是局部变量哦!
    var a;   //局部变量a在这行声明
    alert(a); //a还是为4,这是因为之前已把4赋给a了
  }
  test();
  alert(a); //a为1,这里并不在function scope内,a的值为全局变量的值
</script>

3. 전역 변수가 지역 변수와 동일한 이름을 갖는 경우 지역 변수의 범위를 벗어나면 지역 변수의 범위가 전역 변수의 범위를 덮어씁니다. , 전역 변수 범위로 돌아가고 전역 변수가 지역 변수를 만나면 전역 변수를 어떻게 사용합니까? window.globalVariableName을 사용하세요.


<script>
  var a =1;
  function test(){  
    alert(window.a); //a为1,这里的a是全局变量哦!
    var a=2;   //局部变量a在这行定义
    alert(a); //a为2,这里的a是局部变量哦!
  }
  test();
  alert(a); //a为1,这里并不在function scope内,a的值为全局变量的值
</script>

변수의 범위

1. 변수에는 범위에 따라 전역 변수와 지역 변수 두 가지 유형이 있습니다. 함수에 정의된 변수는 지역변수이고, 지역변수는 함수 내에서만 유효합니다. 로컬 변수와 글로벌 변수가 동일한 변수 이름을 사용하면 로컬 변수가 글로벌 변수를 덮어쓰게 됩니다

<script>   
    //定义全局变量test   
    var test = "全局变量";    
    function checkscope(  )   
    {   
        var test = "局部变量";   
        alert(test);   
    }   
    checkscope(  );    
//在函数里定义的变量为局部变量,局部变量只在函数内有效。   
//如果局部变量和全局变量用相同的变量名,则局部变量将覆盖全局变量   
</script>

2 JavaScript 언어에는 블록 범위가 없습니다

<script>   
    function test(o)       
    {   
        //定义变量i,变量i的作用范围是整个函数   
            var i = 0;   
        if (typeof o == "object")    
        {   
            //定义变量j,变量j的作用范围是整个函数内,而不是if块内。   
                var j = 5;   
                for(var k = 0; k < 10; k++)   
                {   
                //k的作用范围是整个函数内,而不是循环体内   
                    document.write(k);   
                }   
        }      
        //即使出了循环体,k的值依然存在   
        alert(k + "\n" + j);    
    }   
    test(document);   
</script>
.

위 내용은 Javascript 변수 유형 및 범위 예제에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.