프로그래밍 (Programming)/자바스크립트 (JavaScript)
[Javascript/Function] function, inner function, arrow function(자바스크립트, 함수, 내부 함수, 함수 선언식, =>)
Bbaktaeho
2020. 3. 28. 20:53
반응형
📚 function, inner function, arrow function
- function 키워드는 함수를 생성하는 키워드
- 자바스크립트에서 함수는 일급 객체(일급 함수)
- 고차 함수 가능 -> 함수를 인자로 받고 함수를 리턴할 수 있음
📗 function
함수
- 함수 선언
// 함수 선언
function name(params) {
// 함수의 기능
return;
}
function add(a, b) {
return a + b;
}
var result = add(10, 20);
console.log(result);
30
- 기본 매개변수를 지정
function add(a = 1, b = 2) {
return a + b;
}
var result = add(10, 20);
console.log(result);
console.log(add());
30
3
- 함수 표현식
함수 표현식으로 변수에 함수를 할당할 수 있고 이러한 함수를 익명 함수라고도 한다
const add = function(a, b) {
return a + b;
};
const result = add(10, 30);
console.log(result);
40
- 호이스팅(hoisting)
일반적인 선언 방법과 표현식의 차이점은 함수를 구현한 코드의 위치에 차이점이 있다 즉, 호이스팅 차이가 있다
test1("일반 선언식이 실행됨");
test2("함수 표현식이 실행됨");
// 일반적인 함수 선언 방식
function test1(params) {
console.log(params);
}
// 함수 표현식으로 선언한 방식
var test2 = function(params) {
console.log(params);
};
일반 선언식이 실행됨
test2('함수 표현식이 실행됨');
^
TypeError: test2 is not a function
📒 inner function
함수 안에 함수를 선언하고 사용이 가능
- 내부 함수 구현하기
function addSQ(a,b) {
function square(x) {
return x \* x;
}
return square(a) + square(b);
}
var a = addSQ(5,6);
var b = addSQ(7,8);
var c = addSQ(9,10);
console.log(a);
console.log(b);
61
113
181
- 내부 함수를 활용해서 클로저(closure)를 구현
내부 함수를 활용해 클로저 구현이 가능하다. 클로저는 내부 함수를 리턴하는데 이 내부 함수는 외부 함수의 변수나 파라미터를 사용할 수 있다
function closure(a, b) {
return function(c = a, d = b) {
return c + d;
};
}
var result = closure(5, 5);
console.log(result);
console.log(result());
[Function]
10
📒 arrow function
구문이 짧고 항상 익명인 함수
-
일반 함수와의 가장 큰 차이점은 this
-
화살표 함수 전까지 모든 함수는 새로운 this 값을 정의했음
-
화살표 함수 구현
var test = params => {
console.log(params);
};
test("화살표 함수 실행");
화살표 함수 실행
- 매개변수가 하나인 화살표 함수 구현
소괄호를 생략할 수 있다
var test = params => {
console.log(params);
};
test("화살표 함수 실행");
화살표 함수 실행
- 리턴을 생략한 화살표 함수 구현
함수 몸체에 리턴만 존재한다면 중괄호를 생략할 수 있다
// var test = params => {return params*2};
var test = params => params * 2; // 위와 동일한 동작을 함
console.log(test(3));
6
- 바인딩되지 않은 this
화살표 함수는 자신을 포함하는 외부 스코프에서 this를 계승받습니다. 즉, 화살표 함수는 자신만의 this를 생성하지 않습니다.
var test = () => {
console.log(this);
};
test();
{}
-
화살표 함수를 사용하면 안 되는 경우
❌ 객체의 메서드로 선언하는 경우
- 메소드를 소유한 객체가 아닌 상위 컨텍스트의 객체를 가리키게 됨
❌ 생성자의 함수로 사용하는 경우
- 화살표 함수는 prototype을 갖고 있지 않기 때문에 생성자 함수로 사용하면 안 됨
❌ 등등..
반응형