모자딥 13장 스코프

릿·2023년 1월 12일
0

13. 스코프

13.1 스코프란?


스코프 = 식별자가 유효한 범위, 식별자를 검색할 때 사용하는 규칙

13.2 스코프의 종류


13.2.1 전역과 전역 스코프

전역은 전역 스코프를 만들고, 전역에 변수를 선언하면 전역변수가 되며, 어디서든지 참조할 수 있다.

13.2.2 지역과 지역 스코프

지역 = 함수 몸체 내부
지역변수는 자신의 지역 스코프와 하위 지역 스코프에서 유효하다.

13.3 스코프 체인


  • 스코프는 중첩이 가능하다 => 스코프가 함수의 중첩에 의해 계층적 구조를 갖는다.
  • 스코프 체인 : 스코프가 계층적으로 연결된 것
    변수를 참조할 때 자바스크립트 엔진은 스코프 체인을 통해 아래에서 위로 이동하며 선언된 변수를 검색한다.

13.4 함수 레벨 스코프


  • 블록 레벨 스코프 : 모든 코드블록이 지역 스코프를 만드는 것
  • 함수 레벨 스코프 : var키워드로 선언된 변수는 오로지 함수의 코드블록만을 지역 스코프로 인정한다.
var x = 1;

if (true) {
  var x = 10;
}

console.log(x); // 10

var키워드로 선언된 변수는 모두 전역변수이므로 전역변수 x는 중복선언되고 전역변수의 값이 재할당되었다.

13.5 렉시컬 스코프


  1. 함수를 어디서 호출했는지에 따라 함수의 상위 스코프를 결정한다.
    -> 동적 스코프 (호출되는 시점에 상위 스코프가 결정됨)
  2. 함수를 어디서 정의했는지에 따라 함수의 상위 스코프를 결정한다.
    -> 렉시컬 스코프, 정적 스코프 (함수 정의가 평가되는 시점에 상위스코프가 정적으로 결정됨)

자바스크립트는 렉시컬 스코프를 따른다.

profile
항상 재밌는 뭔가를 찾고 있는 프론트엔드 개발자

0개의 댓글