“ 지연되는 프로젝트에 인력을 더 투입하면 오히려 더 늦어진다. ”
- Frederick Philips Brooks
Mythical Man-Month 저자
자바스크립트 콜백함수 종류
콜백함수
-callback function
다른 함수에 전달되어 그 함수가 어떤 이벤트가 발생했을 때 실행되는 함수
즉, 콜백함수는 다른 함수의 인자로 전달되어 호출된다.
{
function func(){
document.write("2. 함수 실행");
}
function callback(str){
document.write("1. 함수 실행");//이게 먼저 실행
str();
}
callback(func);
}
결과값은
1. 함수 실행
2. 함수 실행
func()는 2. 함수 실행을 출력하고, callback은 1. 함수실행을 출력합니다.
그 이후 인자로 전달받은 함수를 호출합니다.
callback(func)를 호출해 callback함수는 func 함수를 인자로 받아 호출합니다.
따라서 callback 함수가 실행될 때는 1.함수 실행 이 먼저 출력되고 그 후 func함수가 실행되어 2. 함수 실행이 출력됩니다.
콜백함수 (반복문)
반복문에서 사용되는 콜백함수의 경우, 일반적으로 배열의 각 요소에 대해 적용됩니다.
예를 들어 javascript에서 forEach()메서드를 사용해 배열의 각 요소를 반복하면 콜백함수가 호출됩니다.
콜백함수의 인자로는 현재 요소, 해당 요소의 인덱스, 배열 전체가 전달됩니다.
{
function func(index){
console.log("함수실행"+index);
}
function callback(num){
for(let i=1; i<=10; i++){
num(i);
}
}
callback(func);
}
결과값은
함수실행1~10까지 출력됩니다.
callback 함수는 num 함수를 인자로 받아 1부터 10까지의 숫자를 인자로 num 함수를 10번 호출합니다.
따라서 func 함수가 10번 호출되면서 index 값이 1부터 10까지 출력됩니다.
콜백함수 (동기/비동기)
동기적 콜백 함수는 호출된 함수가 콜백 함수의 실행이 끝날 때까지 기다립니다. 이 경우 콜백함수는 호출된 함수와 동기적으로 작동하며, 호출된 함수가 실행 중일 때 다른 코드가 실행되지 않습니다.
ex) Array.prototype.forEach()
비동기적 콜백 하뭇는 호출된 함수의 실행과 독립적으로 작동합니다. 호출된 함수가 작업을 완료할 때까지 콜백함수는 기다리지 않고 다른 코드를 실행합니다.
ex) setTimeout(), Node.js의 fs.readaFile()
{
//01
function funcA(){
console.log("funcA가 실행되었습니다.");
}
function funcB(){
console.log("funcB가 실행되었습니다.");
}
funcA();
funcB();
//02
function funcA(){
setTimeout(() => {
console.log("funcA가 실행되었습니다.");
}, 1000)
}
function funcB(){
console.log("funcB가 실행되었습니다.");
}
funcA();
funcB();
//03
function funcA(callback){
setTimeout(() => {
console.log("funcA가 실행되었습니다.");
callback();
}, 1000);
}
function funcB(){
console.log("funcB가 실행되었습니다.");
}
funcA(function(){
funcB();
});
//04. 콜백지옥
function funcA(callback){
setTimeout(() => {
console.log("funcA가 실행되었습니다.");
callback();
}, 1000);
}
function funcB(callback){
setTimeout(() => {
console.log("funcB가 실행되었습니다.");
callback();
}, 1000);
}
function funcC(callback){
setTimeout(() => {
console.log("funcC가 실행되었습니다.");
callback();
}, 1000);
}
function funcD(){
setTimeout(() => {
console.log("funcD가 실행되었습니다.");
}, 1000);
}
funcA(function(){
funcB(function(){
funcC(function(){
funcD();
});
});
});
}
1. 결과값은
funcA
funcB
-각 함수가 실행될 때마다 console.log를 이용해 콘솔에 출력
2. 결과값은
funcB
funcA
-funcA함수에서 setTimeout 을 이용해 1초 후에 함수가 실행되도록 설정
funcA 함수를 호출 한 후 즉시 funcB 함수가 실행
funcB 함수는 funcA 함수가 실행 중인 동안에도 즉시 실행되고 이후 setTimeout 이 끝나면 funcA 함수가 실행되어 콘솔에 출력
3. 결과값은
funcA
funcB
-funcA함수는 콜백 함수를 인자로 받으며, 1초 후에 콜백 함수를 실행
funcA함수를 호출할 때 funcB함수를 실행하는 콜백함수를 인자로 전달하면, funcA 함수가 실행되고 1초 후에 funcB 함수가 실행
4. 결과값은
fucnA
funcB
fucnC
funcD
-setTimeout 을 이용해 일정 시간 후에 실행되도록 설정
funcA 함수를 호출할때 funcB함수를 실행하는 콜백 함수를 인자로 전달하고, funcB 함수를 호출할때 funcC 함수를 실행하는 콜백 함수를 인자로 전달하고, funcC 함수를 호출할때 funcD 함수를 실행하는 콜백 함수를 인자로 전달합니다.
이렇게 중첩된 콜백 함수들이 순서대로 콘솔에 출력됩니다.
이처럼 콜백 함수가 중첩되어 있는 상황을 콜백 지옥 이라고 부릅니다.
이 코드는 가독성을 떨어뜨리고, 유지 봅수를 어렵게 만드는 문제를 야기해 지양하는 것이 좋습니다.
자바스크립트에서는 대부분의 이벤트 처리에 콜백함수를 사용하는데
이벤트가 발생하면 콜백 함수가 호출되어 해당 이벤트에 대한 처리를 수행합니다.
버튼 클릭 이벤트에 대한 콜백 함수는 다음과 같습니다.
button.addEventListener("click", function(){
// 버튼이 클릭되었을 때 실행되는 콜백 함수
});
addEventListnenr 함수는 버튼이 클릭되었을 때 실행할 콜백 함수를 인자로 받는고
이벤트가 발생하면 해당 콜백 함수가 호출되어 실행합니다.