콜백 함수는 다른 함수에 인수로 전달되는 함수입니다. 이를 통해 함수가 다른 함수를 호출할 수 있어 비동기 작업과 모듈식 코드 설계가 가능해집니다.
콜백은 다른 함수에 인수로 전달되어 일부 작업이 완료된 후 실행되는 함수입니다.
function greet(name, callback) { console.log("Hello, " + name); callback(); } function sayGoodbye() { console.log("Goodbye!"); } greet("Alice", sayGoodbye); // Output: // Hello, Alice // Goodbye!
이 예에서 sayGoodbye는 Greeting에 전달된 콜백 함수입니다.
동기 콜백은 함수 내에서 즉시 실행됩니다.
예: 배열 반복
const numbers = [1, 2, 3, 4]; numbers.forEach(function(number) { console.log(number * 2); }); // Output: // 2 // 4 // 6 // 8
여기서 forEach 내부의 콜백 함수는 배열의 각 요소에 대해 실행됩니다.
비동기 콜백은 데이터 가져오기, 타이머 또는 이벤트 처리와 같은 작업에 사용됩니다. 현재 작업이 완료된 후에 실행됩니다.
예: 타이머
console.log("Start"); setTimeout(function() { console.log("This runs after 2 seconds"); }, 2000); console.log("End"); // Output: // Start // End // This runs after 2 seconds
콜백을 허용하는 사용자 정의 함수를 생성할 수 있습니다.
예: 작업 수행
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
콜백을 사용할 때 오류를 콜백 함수에 전달하여 오류를 정상적으로 처리할 수 있습니다.
예: 오류 시뮬레이션
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' }
document.querySelector("button").addEventListener("click", function() { console.log("Button clicked!"); });
setTimeout(function() { console.log("This runs after 1 second"); }, 1000);
콜백은 유용하지만 너무 깊게 중첩되면 콜백 지옥으로 이어질 수 있습니다.
콜백 지옥의 예:
getData(function(data) { processData(data, function(result) { saveData(result, function(response) { console.log("Data saved:", response); }); }); });
최신 JavaScript는 프라미스 또는 async/await를 사용하여 비동기 작업을 보다 깔끔하게 처리합니다.
콜백을 이해하는 것은 JavaScript 프로그래밍을 마스터하기 위한 기본 단계입니다.
안녕하세요. 저는 Abhay Singh Kathayat입니다!
저는 프론트엔드와 백엔드 기술 모두에 대한 전문 지식을 갖춘 풀스택 개발자입니다. 저는 효율적이고 확장 가능하며 사용자 친화적인 애플리케이션을 구축하기 위해 다양한 프로그래밍 언어와 프레임워크를 사용하여 작업합니다.
제 비즈니스 이메일(kaashshorts28@gmail.com)로 언제든지 연락주세요.
위 내용은 JavaScript의 콜백 함수 이해: 종합 안내서의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!