let, const 키워드와 블록 레벨 스코프

김민수·2023년 10월 17일
0
post-thumbnail

1. var 키워드로 선언한 변수의 문제점

변수 중복 선언 허용

var x = 1;
var y = 1;

var x = 100   // 문제 1. 중복 선언 가능
var y;        // 문제 2. 초기화문이 없는 변수 선언문은 무시된다.

console.log(x) // 100
console.log(y) // 1

함수 레벨 스코프

  • 함수의 코드 블록만을 지역 스코프로 인정하기 때문에 함수 외부에서 var 키워드로 선언한 변수는 코드 블록 내에서 선언해도 모두 전역 변수가 된다.
var a = 0;
console.log(a)     // 0
if(true){
    var a = 1;
    console.log(a) // 1
}
console.log(a)     // 1

변수 호이스팅

  • 변수 호이스팅에 의해 var 키워드로 선언한 변수는 변수 선언문 이전에 undefined로 참조할 수 있다.

2. let 키워드

변수 중복 선언 금지

  • 만일 중복 선언을 할 경우 문법 에러가 발생한다.

블록 레벨 스코프

  • 모든 코드 블록을 지역 스코프로 인정하는 블록 레벨 스코프를 따른다.

변수 호이스팅

var 키워드

선언단계초기화 단계
할당단계
  • 런타임 이전에 자바스크립트 엔진에 의해 암묵적으로 선언 단계초기화 단계가 한꺼번에 진행된다.
  • 선언 단계에서 스코프에 변수 식별자를 등록하고, 즉시 초기화 단계에서 undefined로 변수를 초기화 한다.

let 키워드

선언단계
일시적 사각지대(TDZ)
초기화 단계
할당 단계
  • 선언 단계초기화 단계가 분리되어 진행된다.
  • 런타임 이전에 자바스크립트 엔진에 의해 암묵적으로 선언 단계가 먼저 실행되지만, 초기화 단계에 도달했을 때 실행된다.
  • 초기화 단계가 실행되기 이전에 변수에 접근하려고 하면 참조 에러가 발생한다.
  • 일시적 사각지대 : 스코프의 시작 지점부터 초기화 시작 지점까지 변수를 참조할 수 없는 구간
  • let, const, class를 사용한 선언문은 호이스팅이 발생하지 않는 것처럼 동작한다.

전역 객체와 let

  • var = 전역 객체 window의 프로퍼티가 된다.
  • let = 전역 객체의 프로퍼티가 아니다! 보이지 않는 개념적인 블록내에 존재한다. (추후 개봉박두!)

3. const 키워드

const 키워드는 상수를 사용하기 위해 주로 사용한다.

선언과 초기화

  • const 키워드로 선언한 변수는 선언과 초기화 동시에 해야 한다. (안할 경우 문법 에러)
  • 블록 레벨 스코프를 가지고 있다.
  • 변수 호이스팅이 발생하지 않는 것처럼 동작한다.

재할당 금지

  • const const 키워드로 선언한 변수는 재할당이 금지된다. (할 경우 타입 에러)

상수

  • 상수 : 재할당이 금지된 변수 (객체는 좀..)
  • 상수는 상태 유지와 가독성, 유지보수의 편의를 위해 적극적으로 사용한다.
  • 언더스코어로 구분해서 스네이크 케이스로 표현하는 것이 일반적이다.

const 키워드와 객체

  • const 키워드로 선언된 변수에 객체를 할당한 경우 값을 변경할 수 있다.
  • const 키워드는 재할당을 금지할 뿐 "불변"을 의미하지는 않는다.

4. var vs let vs const

  • ES6 사용한다면 var 사용하지 않기!
  • 재할당이 필요한 경우 let 사용! 스코프는 최대한 좁게!
  • 변경이 발생하지 않고 읽기 전용으로 사용하는 원시 값과 객체에는 const를 사용한다.
    const 키워드는 재할당 금지하므로 var, let보다 안전하다.

0개의 댓글