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

화살표 함수 표현

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

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

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

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

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

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

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

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

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

> function f(){
  console.log(1);
  return 2;
}

> let y = () => { f() }
> let z = () => f()

> y()
// output: 1
// return: undefined

> z()
// output: 1
// return: 2

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

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

> function A() {
  this.count = 0;
  setInterval(() => {this.count++;}, 1000);
}

> let a = new A()
// a = A {count: 1}
// a의 카운트는 1초마다 증가하고 있다. 이는 객체마다 독립적이다.

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

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

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

Links

Last updated