화살표 함수 표현 (arrow function expression)

화살표 함수 표현

자바스크립트로 서버사이드, 클라이언트사이드 모두 개발하면서 () => {} 이나 () => x 와 같은 문법을 많이 사용했었다.

그 이유는 그 많던 이름없는 function 키워드가 사라졌고, 코드가 짧아 읽기에도 편했기 때문이다.

하지만 그 문법과 동작을 자세히 살펴본 적이 없었다.

화살표 함수는 ES6에서 추가된 문법이다. 화살표 함수는 항상 이름이 없는 "익명"이다.

(param1, param2,, paramN) => { statements }
(param1, param2,, paramN) => expression
// 다음과 동일함:  => { return expression; }

// 매개변수가 하나뿐인 경우 괄호는 선택사항:
(singleParam) => { statements }
singleParam => { statements }

// 매개변수가 없는 함수는 괄호가 필요:
() => { statements }

화살표(=>)다음의 괄호의 유무는 실행만 하는 지와 값을 반환하는 지 여부의 차이이다.

함수 정의를 어떻게 표현하는 지의 대한 문법이므로, 아래 실행 결과로 확인해봤다.

한가지 또 알게 된 사실은, 이 문서arrow-up-right에 따르면 this을 바인딩이 되지 않는다고 말한다. 즉, this 가 없다.

그럼 이 익명 함수에서 사용하는 this는 대체 무엇을 가리킬까.

자신을 둘러싸고 있는 렉시컬 스코프(Lexical scope)의 this를 사용한다. 즉, 이 함수가 선언된 스코프의 this 를 사용한다.

위 코드는 A 라는 클래스를 만들어서 변수를 추가하였고, 화살표 함수로 count 변수를 1초마다 1씩 증가하게 한다.

(사실 자바스크립트의 모든 클래스 생성자는 function 이기 때문에...)

Links

Last updated