1. var 키워드로 선언한 변수의 문제점
변수 중복 선언 허용
var x = 1;
var y = 1;
var x = 100
var y;
console.log(x)
console.log(y)
함수 레벨 스코프
- 함수의 코드 블록만을 지역 스코프로 인정하기 때문에 함수 외부에서 var 키워드로 선언한 변수는 코드 블록 내에서 선언해도 모두 전역 변수가 된다.
var a = 0;
console.log(a)
if(true){
var a = 1;
console.log(a)
}
console.log(a)
변수 호이스팅
- 변수 호이스팅에 의해 var 키워드로 선언한 변수는 변수 선언문 이전에 undefined로 참조할 수 있다.
2. let 키워드
변수 중복 선언 금지
- 만일 중복 선언을 할 경우 문법 에러가 발생한다.
블록 레벨 스코프
- 모든 코드 블록을 지역 스코프로 인정하는 블록 레벨 스코프를 따른다.
변수 호이스팅
var 키워드
- 런타임 이전에 자바스크립트 엔진에 의해 암묵적으로
선언 단계
와 초기화 단계
가 한꺼번에 진행된다.
- 선언 단계에서 스코프에 변수 식별자를 등록하고, 즉시 초기화 단계에서 undefined로 변수를 초기화 한다.
let 키워드
선언 단계
와 초기화 단계
가 분리되어 진행된다.
- 런타임 이전에 자바스크립트 엔진에 의해 암묵적으로 선언 단계가 먼저 실행되지만, 초기화 단계에 도달했을 때 실행된다.
- 초기화 단계가 실행되기 이전에 변수에 접근하려고 하면 참조 에러가 발생한다.
- 일시적 사각지대 : 스코프의 시작 지점부터 초기화 시작 지점까지 변수를 참조할 수 없는 구간
- 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보다 안전하다.