모던 자바스크립트 튜토리얼
ko.javascript.info
함수 표현식보다 단순하고 간결한 문법으로 함수를 만들 수 있는 방법이 있다.
바로 화살표 함수(arrow function)를 사용하는 것이다. 화살표 함수라는 이름은 문법의 생김새를 차용해 지어졌다.
let func = (arg1, arg2, ...argN) => expression
이렇게 코드를 작성하면 인자 arg1...argN
를 받는 함수 func
이 만들어진다. 함수 func
는 화살표 =>
우측의 표현식(expression)
을 평가하고, 평가 결과를 반환한다.
아래 함수의 축약 버전이라고 할 수 있다.
let func = function(arg1, arg2, ...argN) {
return expression;
};
조금 더 구체적인 예시를 살펴보자.
let sum = (a, b) => a + b;
/* 위 화살표 함수는 아래 함수의 축약 버전이다.
let sum = function(a, b) {
return a + b;
}
*/
alert( sum(1, 2) ); // 3
(a, b) => a + b
는 인수 a
와 b
를 받는 함수이다. (a, b) => a + b
는 실행되는 순간 a + b
를 평가하고 그 결과를 반환한다.
let double = n => n * 2;
// let double = function(n) { return n * 2 }과 거의 동일
alert( double(3) ); // 6
let sayHi = () => alert("안녕하세요!");
sayHi();
화살표 함수는 함수 표현식과 같은 방법으로 사용할 수 있다.
아래 예시와 같이 함수를 동적으로 만들 수 있다.
let age = prompt("나이를 알려주세요.", 18);
let welcome = (age < 18) ?
() => alert('안녕'):
() => alert("안녕하세요!");
welcome();
함수 표현식을 접하면 가독성이 떨어진다. 익숙하지 않기 때문이다. 하지만 문법이 눈에 익기 시작하면 적응 하기 쉽다.
함수 본문이 한 줄인 간단한 함수는 화살표 함수를 사용해서 만드는게 편리하다. 타이핑을 적게 해도 함수를 만들 수 있다는 장점이 있다.
위에서 소개한 화살표 함수들은 =>
왼쪽에 있는 인수를 이용해 =>
오른쪽에 있는 표현식을 평가하는 함수들이었다.
그런데 평가해야 할 표현식이나 구문이 여러 개인 함수가 있을 수도 있다. 이 경우 역시 화살표 함수 문법을 사용해 함수를 만들 수 있다. 다만, 이때는 중괄호 안에 평가해야 할 코드를 넣어주어야 한다. 그리고 return
지시자를 사용해 명시적으로 결과값을 반환해 주어야 한다.
let sum = (a, b) => { // 중괄호는 본문 여러 줄로 구성되어 있음을 알려준다.
let result = a + b;
return result; // 중괄호를 사용했다면, return 지시자로 결과값을 반환해주어야 한다.
};
alert( sum(1, 2) ); // 3
화살표 함수는 본문이 한 줄인 함수를 작성할 때 유용하다. 본문이 한 줄이 아니라면 다른 방법으로 화살표 함수를 작성해야 한다.
(...args) => expression
- 화살표 오른쪽에 표현식을 둔다. 함수는 이 표현식을 평가하고, 평가 결과를 반환한다.(...args) => { body }
- 본문이 여러 줄로 구성되었다면 중괄호를 사용해야 한다. 다만, 이 경우는 반드시 return
지시자를 사용해 반환 값을 명기해 주어야 한다.함수 표현식을 사용해 만든 아래 함수를 화살표 함수로 바꿔보세요.
function ask(question, yes, no) {
if (confirm(question)) yes()
else no();
}
ask(
"동의하십니까?",
function() { alert("동의하셨습니다."); },
function() { alert("취소 버튼을 누르셨습니다."); }
);
✔해답
function ask(question, yes, no) { if (confirm(question)) yes() else no(); } ask( "동의하십니까?", () => alert("동의하셨습니다."), () => alert("취소 버튼을 누르셨습니다.") );
함수 선언문이 아닌 함수 표현식을 화살표 함수로 바꾸라고 했기 때문에 아래 부분만 화살표 함수로 변경