예제) MDN - Array.prototype.map()
설명 보신 적 있으시죠?
arr.map(**callback**(currentValue[, index[, array]])[, thisArg])
여러 라이브러리에서 콜백함수인 경우, callback
또는 cb
, callbackFn
등등 으로 표기
showMessage
, Array.map
등// closeFn가 바로 콜백함수!
// closeFn가 비동기로 쓰인건 아닙니다. (sync callback - 동기 콜백)
function showMessage(msg, closeFn) {
// 로직로직~~
closeFn(true);
}
// map 함수의 인자인 el => el*2 함수가 콜백함수!
// 얘도 비동기 아닙니다. (sync callback)
[1,2,3].map(el => el*2);
// addEventListener의 두 번째 인자도 콜백함수!
// 얘가 바로~ 비동기로 동작! (async callback)
window.addEventListener('keydown', e => {
// 로직
});
// setTimeout 함수에 넘긴 익명함수가 콜백함수!
// Hello 또한 3초뒤에 나오죠. 비동기 동작! (async callback)
setTimeout(function(){
alert("Hello");
}, 3000);