상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - 자바스크립트에서 함수의 비동기 처리를 위한 Promise 사용법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
JavaScript에서 비동기 처리를 위해 Promise를 사용하는 방법은 현대 <a href='https://sangseek.com/sangseeks/웹 개발/ko'>웹 개발</a>에서 매우 중요한 개념입니다. Promise는 비동기 작업의 완료 또는 실패를 나타내는 객체로, 비동기 작업이 성공적으로 완료되면 결과 값을 반환하고, 실패하면 오류를 반환합니다. 이를 통해 코드의 가독성을 높이고, 콜백 헬(callback hell) 문제를 해결할 수 있습니다. Promise의 기본 구조 Promise는 `new Promise()` 생성자를 사용하여 생성합니다. 이 생성자는 두 개의 인자를 받는 함수를 인자로 받습니다: `resolve`와 `reject`. `resolve`는 비동기 작업이 성공적으로 완료되었을 때 호출되고, `reject`는 실패했을 때 호출됩니다. ```javascript const myPromise = new Promise((resolve, reject) => { // 비동기 작업 수행 const success = true; // 예시로 성공 여부를 나타내는 변수 if (success) { resolve("작업이 성공적으로 완료되었습니다."); } else { reject("작업이 실패하였습니다."); } }); ``` <a href='https://sangseek.com/sangseeks/Promise 사용/ko'>Promise 사용</a>하기 Promise를 사용하여 비동기 작업을 수행할 때는 `.then()`과 `.catch()` 메서드를 사용합니다. `.then()` 메서드는 Promise가 성공적으로 완료되었을 때 호출되며, `.catch()` 메서드는 실패했을 때 호출됩니다. ```javascript myPromise .then(result => { console.log(result); // "작업이 성공적으로 완료되었습니다." }) .catch(error => { console.error(error); // "작업이 실패하였습니다." }); ``` Promise 체이닝 Promise는 체이닝이 가능하여, 여러 개의 비동기 작업을 순차적으로 수행할 수 있습니다. 각 `.then()` 메서드는 이전 Promise의 결과를 받아 처리할 수 있습니다. ```javascript const fetchData = () => { return new Promise((resolve) => { setTimeout(() => { resolve("데이터를 가져왔습니다."); }, 1000); }); }; fetchData() .then(data => { console.log(data); // "데이터를 가져왔습니다." return "다음 작업을 수행합니다."; }) .then(nextData => { console.log(nextData); // "다음 작업을 수행합니다." }) .catch(error => { console.error("오류 발생:", error); }); ``` <a href='https://sangseek.com/sangseeks/Promise.all/ko'>Promise.all</a> 여러 개의 Promise를 동시에 실행하고, 모든 Promise가 완료될 때까지 기다리려면 `Promise.all()` 메서드를 사용할 수 있습니다. 이 메서드는 배열 형태의 Promise를 인자로 받아, 모든 Promise가 성공적으로 완료되면 결과를 배열로 반환합니다. ```javascript const promise1 = Promise.resolve(3); const promise2 = new Promise((resolve) => setTimeout(resolve, 1000, "foo")); const promise3 = new Promise((resolve, reject) => setTimeout(reject, 500, "오류 발생")); Promise.all([promise1, promise2]) .then((values) => { console.log(values); // [3, "foo"] }) .catch((error) => { console.error("오류 발생:", error); }); Promise.all([promise1, promise2, promise3]) .then((values) => { console.log(values); }) .catch((error) => { console.error("오류 발생:", error); // "오류 발생: 오류 발생" }); ``` Promise.race `Promise.race()` 메서드는 주어진 Promise 중 가장 먼저 완료된 Promise의 결과를 반환합니다. 이 메서드는 여러 비동기 작업 중 가장 빠른 결과를 얻고자 할 때 유용합니다. ```javascript const promise1 = new Promise((resolve) => setTimeout(resolve, 100, "첫 번째 작업 완료")); const promise2 = new Promise((resolve) => setTimeout(resolve, 200, "두 번째 작업 완료")); Promise.race([promise1, promise2]) .then((result) => { console.log(result); // "첫 번째 작업 완료" }); ``` async/await Promise를 더욱 간결하게 사용할 수 있는 방법으로 `async`와 `await` 키워드를 사용할 수 있습니다. `async` 함수는 항상 Promise를 반환하며, `await` 키워드는 Promise가 해결될 때까지 기다립니다. 이를 통해 비동기 코드를 동기 코드처럼 작성할 수 있습니다. ```javascript const fetchDataAsync = () => { return new Promise((resolve) => { setTimeout(() => { resolve("비동기 데이터"); }, 1000); }); }; const executeAsync = async () => { try { const data = await fetchDataAsync(); console.log(data); // "비동기 데이터" } catch (error) { console.error("오류 발생:", error); } }; executeAsync(); ``` 결론 Promise는 JavaScript에서 비동기 처리를 위한 강력한 도구입니다. 비동기 작업을 더 쉽게 관리하고, 코드의 가독성을 높이며, 에러 처리를 간편하게 할 수 있게 해줍니다. `Promise.all`, `Promise.race`, `async/await`와 같은 기능을 통해 복잡한 비동기 로직을 간단하게 처리할 수 있습니다. 이러한 Promise의 사용법을 잘 이해하고 활용하면, 비동기 프로그래밍에서 발생할 수 있는 여러 문제를 효과적으로 해결할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기