스코프 (Scope)
스코프(Scope)라는 영어 단어 자체는 '범위'라는 의미를 가진다.
컴퓨터 공학, 그리고 JavaScript에서도 '범위'의 의미를 가지고 있다.
JavaScript에만 국한된 개념은 아니다.
스코프란?
스코프의 정의는 "식별자 접근 규칙에 따른 유효 범위"이다.
식별자(변수, 함수, 클래스)에 접근할 수 있는 범위가 존재한다.
범위는 중괄호(블록) 또는 함수에 의해 나눠진다.
그 범위를 스코프라고 부른다.
그래서 각각을 Block Scope와 Function Scope라고 부른다.
스코프의 주요 규칙
바깥쪽 스코프에서 선언한 식별자는 안쪽 스코프에서 사용 가능하다.
반면, 안쪽에서 선언한 식별자는 바깥쪽 스코프에서는 사용할 수 없다.
가장 바깥쪽의 스코프를 전역 스코프(Global Scope)라고 부른다.
전역이 아닌 다른 스코프는 전부 지역 스코프(Local Scope)이다.
전역 스코프에서 선언한 변수는 전역 변수이다.
지역 스코프에서 선언한 변수는 지역 변수이다.
지역 변수는 전역 변수보다 더 높은 우선순위를 가진다.
스코프의 종류
스코프의 종류에는 블록 스코프와 함수 스코프 두 가지가 있다.
화살표 함수는 함수 스코프가 아니다.
화살표 함수는 블록 스코프로 취급됨을 주의하자.
스코프와 var, let, const 키워드
for(let i=0; i<10; i++) {
console.log(i);
}
// 전역스코프에서 선언한 변수 i 는 존재하지 않음으로 아래에서 ReferenceErrer을 일으킨다.
console.log(i); // ReferenceErrer
블록 스코프 안에서 let과 const 키워드로 선언한 변수는 스코프 안에서만 참조 가능하다.
그런데 var 키워드로 선언한 변수는 블록 스코프를 무시하고 스코프 울타리 밖에서도 접근 가능하다. (var는 Only 함수 스코프만 따른다.)
for(var i=0; i<10; i++) {
console.log(i);
}
// var 키워드로 선언한 변수 i 는 지역 스코프에서 선언되었지만 모든 스코프에서 접근 가능하다.
console.log(i); // 9
스코프와 관련해서 변수 선언시 주의점
Window 객체는 only 브라우저에만 존재하는 객체이다.
브라우저의 창(window)를 의미하는 객체이다.
그런데 별개로 전역 영역을 담고 있기도 하다.
그래서 함수 선언식으로 함수를 선언하거나 var 키워드로 변수를 선언하면 window 객체에 속해진다.
가장 바깥 스코프에 정의한 변수가 전역 변수이다.
즉, 어디서든 접근이 가능하다.
전역 변수를 최소화 하면 side effect
(의도하지 않은 로직에 의해 문제 발생)를 줄일 수 있다.
그런데 그러한 전역 변수를 심지어 var로 선언하는 경우 문제가 될 수 있다.
-전역 변수는 어디서나 접근이 가능하다.
-var 키워드는 블록 스코프를 무시한다.
-재선언과 재할당을 할 수 있다.
-전역 변수를 var로 선언해서 브라우저의 내장 기능을 못하게 만들 수도 있다.
선언 없이 변수를 할당하면 해당 변수는 var로 선언한 전역 변수처럼 취급된다.
실수를 방지하기 위해 Strict Mode를 사용할 수 있다.
-Strict Mode는 브라우저가 보다 엄격하게 작동하도록 만들어준다.
-"선언 없는 변수 할당"의 경우도 에러로 판단해준다.
-적용하려면, js 파일 상단에 'use strict'라고 입력하면 된다. (따옴표 포함)