> 웹 프론트엔드 > JS 튜토리얼 > JavaScript의 콜백 함수 이해: 종합 안내서

JavaScript의 콜백 함수 이해: 종합 안내서

Patricia Arquette
풀어 주다: 2024-12-24 00:07:10
원래의
343명이 탐색했습니다.

Understanding Callback Functions in JavaScript: A Comprehensive Guide

JavaScript의 콜백 함수

콜백 함수는 다른 함수에 인수로 전달되는 함수입니다. 이를 통해 함수가 다른 함수를 호출할 수 있어 비동기 작업과 모듈식 코드 설계가 가능해집니다.


1. 콜백 함수 이해

정의

콜백은 다른 함수에 인수로 전달되어 일부 작업이 완료된 후 실행되는 함수입니다.

기본 예시

function greet(name, callback) {
  console.log("Hello, " + name);
  callback();
}

function sayGoodbye() {
  console.log("Goodbye!");
}

greet("Alice", sayGoodbye);
// Output:
// Hello, Alice
// Goodbye!
로그인 후 복사

이 예에서 sayGoodbye는 Greeting에 전달된 콜백 함수입니다.


2. 동기식 콜백

동기 콜백은 함수 내에서 즉시 실행됩니다.

예: 배열 반복

const numbers = [1, 2, 3, 4];

numbers.forEach(function(number) {
  console.log(number * 2);
});
// Output:
// 2
// 4
// 6
// 8
로그인 후 복사

여기서 forEach 내부의 콜백 함수는 배열의 각 요소에 대해 실행됩니다.


3. 비동기 콜백

비동기 콜백은 데이터 가져오기, 타이머 또는 이벤트 처리와 같은 작업에 사용됩니다. 현재 작업이 완료된 후에 실행됩니다.

예: 타이머

console.log("Start");

setTimeout(function() {
  console.log("This runs after 2 seconds");
}, 2000);

console.log("End");
// Output:
// Start
// End
// This runs after 2 seconds
로그인 후 복사

4. 맞춤형 콜백 함수

콜백을 허용하는 사용자 정의 함수를 생성할 수 있습니다.

예: 작업 수행

function performOperation(a, b, callback) {
  const result = a + b;
  callback(result);
}

performOperation(5, 3, function(result) {
  console.log("The result is:", result);
});
// Output:
// The result is: 8
로그인 후 복사

5. 콜백으로 오류 처리

콜백을 사용할 때 오류를 콜백 함수에 전달하여 오류를 정상적으로 처리할 수 있습니다.

예: 오류 시뮬레이션

function fetchData(callback) {
  const error = false;
  const data = { id: 1, name: "Alice" };

  if (error) {
    callback("Error occurred", null);
  } else {
    callback(null, data);
  }
}

fetchData(function(err, data) {
  if (err) {
    console.log(err);
  } else {
    console.log("Data fetched:", data);
  }
});
// Output:
// Data fetched: { id: 1, name: 'Alice' }
로그인 후 복사

6. 콜백의 일반적인 사용 사례

  1. 이벤트 처리:
   document.querySelector("button").addEventListener("click", function() {
     console.log("Button clicked!");
   });
로그인 후 복사
  1. 타이머:
   setTimeout(function() {
     console.log("This runs after 1 second");
   }, 1000);
로그인 후 복사
  1. API 호출: 콜백은 기존 AJAX 요청과 이전 스타일 API에서 널리 사용됩니다.

7. 콜백과 약속

콜백은 유용하지만 너무 깊게 중첩되면 콜백 지옥으로 이어질 수 있습니다.

콜백 지옥의 예:

getData(function(data) {
  processData(data, function(result) {
    saveData(result, function(response) {
      console.log("Data saved:", response);
    });
  });
});
로그인 후 복사

최신 JavaScript는 프라미스 또는 async/await를 사용하여 비동기 작업을 보다 깔끔하게 처리합니다.


8. 콜백 함수의 장점

  • 비동기 프로그래밍을 활성화합니다.
  • 모듈식이며 재사용 가능한 코드를 장려하세요.
  • 맞춤형 동작을 촉진합니다.

9. 콜백 함수의 단점

  • 콜백 지옥이 발생할 수 있습니다(깊게 중첩된 콜백).
  • 복잡한 시나리오에서는 읽고 디버그하기가 어렵습니다.

10. 요약

  • 콜백은 다른 함수에 인수로 전달되는 함수입니다.
  • JavaScript의 비동기 프로그래밍에 필수적입니다.
  • 콜백을 사용할 때는 항상 오류를 올바르게 처리하세요.
  • 보다 깔끔하고 유지관리가 쉬운 코드를 위해 Promise나 async/await 사용을 고려해 보세요.

콜백을 이해하는 것은 JavaScript 프로그래밍을 마스터하기 위한 기본 단계입니다.

안녕하세요. 저는 Abhay Singh Kathayat입니다!
저는 프론트엔드와 백엔드 기술 모두에 대한 전문 지식을 갖춘 풀스택 개발자입니다. 저는 효율적이고 확장 가능하며 사용자 친화적인 애플리케이션을 구축하기 위해 다양한 프로그래밍 언어와 프레임워크를 사용하여 작업합니다.
제 비즈니스 이메일(kaashshorts28@gmail.com)로 언제든지 연락주세요.

위 내용은 JavaScript의 콜백 함수 이해: 종합 안내서의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿