-
유효범위(Scope)는 변수의 수명을 의미한다.
var vscope = 'global'; function fscope(){ alert(vscope); } fscope();
함수 밖에서 변수를 선언하면 그 변수는 전역변수가 된다. 전역변수는 에플리케이션 전역에서 접근이 가능한 변수다. 다시 말해서 어떤 함수 안에서도 그 변수에 접근 할 수 있다. 그렇기 때문에 함수 fscope 내에서 vscope를 호출 했을 때 함수 밖에서 선언된 vscope의 값 global이 반환된 것이다. 아래 예제를 보자. 결과는 '함수안 local'과 '함수밖 global'이 출력된다.
var vscope = 'global'; function fscope(){ var vscope = 'local'; alert('함수안 '+vscope); } fscope(); alert('함수밖 '+vscope);
지역변수의 유효범위는 함수 안이고, 전역변수의 유효범위는 에플리케이션 전역인데, 같은 이름의 지역변수와 전역변수가 동시에 정의되어 있다면 지역변수가 우선한다는 것을 알 수 있다.
함수밖에서도 vscope의 값이 local인 이유는 무엇일까? 그것은 함수 fscope의 지역변수를 선언할 때 var를 사용하지 않았기 때문이다. var를 사용하지 않은 지역변수는 전역변수가 된다. 따라서 3행은 전역변수의 값을 local로 변경하게 된 것이다. var을 쓰는 것과 쓰지 않는 것의 차이를 이해해야 한다.
전역변수는 여러가지 이유로 그 값이 변경될 수 있기 때문에 사용하지 않는 것이 좋다.
변수를 선언할 때는 꼭 var을 붙이는 것을 습관화해야 한다. 전역변수를 사용해야 하는 경우라면 그것을 사용하는 이유를 명확히 알고 있을 때 사용하도록 하자.
유효범위의 효용
아래 두개의 예제는 변수 i를 지역변수로 사용했을 때와 전역변수로 사용했을 때의 차이점을 보여준다. 전역변수는 각기 다른 로직에서 사용하는 같은 이름의 변수값을 변경시켜서 의도하지 않은 문제를 발생시킨다.
지역변수의 사용
function a (){ var i = 0; } for(var i = 0; i < 5; i++){ a(); document.write(i); } 실행결과 01234
전역변수의 사용
function a (){ i = 0; } for(i = 0; i < 5; i++){ a(); document.write(i); } 실행결과 무한반복
불가피하게 전역변수를 사용해야 하는 경우는 하나의 객체를 전역변수로 만들고 객체의 속성으로 변수를 관리하는 방법을 사용한다. 전역변수를 사용하고 싶지 않다면익명함수를 호출함으로써 이러한 목적을 달성할 수 있다
유효범위의 대상 (함수)
자바스크립트는 함수에 대한 유효범위만을 제공한다. 많은 언어들이 블록(대체로 {,})에 대한 유효범위를 제공하는 것과 다른 점이다. 자바스크립트의 지역변수는 함수에서만 유효하다.
정적 유효범위
자바스크립트는 함수가 선언된 시점에서의 유효범위를 갖는다. 이러한 유효범위의 방식을 정적 유효범위(static scoping), 혹은 렉시컬(lexical scoping)이라고 한다.
'Blog > 생활코딩 - 자바스크립트 기본' 카테고리의 다른 글
[클로저] (0) 2021.08.20 [값으로서의 함수와 콜백] (0) 2021.08.20 [함수지향] (1) 2021.08.18 [UI와 API] (0) 2021.08.18 [모듈] (0) 2021.08.18 댓글