1 분 소요


1. 값


  • 식(표현식)이 평가되어 생성된 결과를 말한다.
  • 값은 데이터 타입을 가지고, 메모리에 저장된다.
// 10 + 20이 평가되어 값 30을 생성
10 + 20;  // 30


2. 리터럴


  • 리터럴사람이 이해할 수 있는 문자 또는 약속된 기호를 사용해 값을 생성하는 표기법.
  • 자바스크립트 엔진은 코드를 실행하는 런타임에 리터럴을 평가해 값을 생성함.

* 리터럴
정수리터럴, 부동소수점리터럴, 2진수리터럴, 문자열리터럴, 불리언리터럴, null리터럴, undefined리터럴, 객체리터럴, 배열리터럴, 함수리터럴, 정규표현식리터럴


3. 표현식


  • 표현식은 값으로 평가될 수 있는 문.
  • 표현식이 평가되면 새로운 값을 생성하거나 기존 값을 참조한다.
  • 표현식은 값처럼 사용될 수 있다.


4. 문


  • 프로그램을 구성하는 기본 단위이자 최소 실행 단위.
  • 문의 집합 → 프로그램 / 문을 작성하고 나열 → 프로그래밍
  • 선언문, 할당문, 조건문, 반복문 등

  • 토큰문법적인 의미를 가지고, 문법적으로 더 이상 나눌 수 없는 코드의 기본요소를 의미
  • 문은 여러 토큰으로 구성
  • 키워드, 식별자, 연산자, 리터럴, 세미콜론, 마침표 등은 문법적인 의미를 가지고 더 이상 나눌 수 없음 → 토큰


5. 세미콜론과 세미콜론 자동 삽입 기능


자바스크립트 엔진은 세미콜론으로 문의 종료 위치를 파악하고 순차적으로 실행한다.

코드블록({…})은 자체종결성을 가지기 때문에 세미콜론을 붙이지 않는다.

* 세미콜론 자동 삽입 기능(ASI)
자바스크립트 엔진은 소스코드를 해석할때 문의 끝이라고 예측되는 지점에 세미콜론을 자동으로 붙여준다.


6. 표현식인 문과 표현식이 아닌 문


구별하는 방법 → 변수에 할당하는 것

표현식인 문 값으로 평가(변수에 할당 가능) var temp = 1 + 2
표현식이 아닌 문 값으로 평가되지 않음(할당x) var temp = var x



이웅모 선생님의 모던 자바스크립트 Deep Dive를 공부하기 위해 정리한 글입니다.
혹시나 보시다가 고칠 부분이나 마음에 안드시는 부분이 있다면 말씀해주시면 감사하겠습니다!