개발자_이훈규
천천히, 빠르게. 개발자의 Repository
개발자_이훈규
전체 방문자
오늘
어제
  • 분류 전체보기 (473)
    • 티스토리 (4)
    • 개발자 뉴스 (2)
    • 소프트웨어 (203)
      • C (7)
      • c++ (25)
      • Objective-C (3)
      • Do it! 반응형 웹디자인 (4)
      • openGL (8)
      • Java (24)
      • Jni (3)
      • Android (9)
      • Wordpress (2)
      • 버그 만난 후 느낀점 (2)
      • Git (3)
      • node js (2)
      • window tablet (1)
      • HTML (3)
      • javascript (3)
      • perl (1)
      • AngularJS (0)
      • JSON (0)
      • Docker (3)
      • python (5)
      • jQuery (1)
      • MFC (4)
      • cocos studio (6)
      • Golang (1)
      • SQLite3 (0)
      • Spring Boot (8)
      • thymeleaf (0)
      • Django (0)
      • iOS (3)
      • skia (0)
      • VBA (0)
      • PHP (2)
      • Oracle (1)
      • JSP (0)
      • R (0)
    • TCP IP (2)
    • 금융 (0)
      • 금융 Study (0)
      • 금융 Archive (0)
      • 금융 Article (0)
    • 개인 프로젝트 (7)
      • gif 홈페이지 만들기 (0)
      • study app만들기 (0)
      • 크롤러 만들기 (1)
      • 카툰 홈페이지 만들기 (1)
      • 외주 홈페이지 만들기 (3)
      • 웹 홈페이지 만들기 (0)
      • 미디어 서버 만들기 (0)
      • 소개팅 어플 만들기 (0)
      • 인스타그램 풀스택 클론 코딩(인강 노트) (0)
      • 주식 모의거래 만들기 (1)
    • html php mysql (0)
    • node.Js (2)
    • 일상 (2)
    • 빈공간 uml 공부 (0)
    • Ubuntu(linux) (12)
    • 맥OS (10)
      • android 설치하기 (2)
    • Programming quizzes (0)
    • IoT (구 유비쿼터스) (16)
      • 라즈베리 파이 (11)
      • 아두이노 (5)
    • 하드웨어 (5)
      • 아수스 비보탭 노트8 asus vivotap no.. (2)
      • 크레마 카르타 (3)
    • 분석할 문장, 구문, 코드 (0)
    • 키보드 (1)
      • 해피해킹 (1)
    • 코드 라이언 (0)
    • 전자기기 (4)
    • Ted (0)
    • NAS (0)
    • 알고리즘 (0)
    • 연합인포맥스 (0)
    • 이벤트 응모함 (4)

블로그 메뉴

  • 홈
  • 태그
  • 미디어로그
  • 위치로그
  • 방명록

공지사항

인기 글

태그

  • 개발
  • 에러
  • 우분투
  • 라즈베리 파이
  • GIT
  • C++
  • error
  • Example
  • 설명
  • CODE
  • install
  • 예제
  • ubuntu
  • 설치
  • 코드
  • C
  • 방법
  • Java
  • Python
  • 소스

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
개발자_이훈규

천천히, 빠르게. 개발자의 Repository

소프트웨어/javascript

promise의 엉뚱한 생각 - promise 중간에 빠져나오기

2021. 7. 21. 08:56
new Promise((resolve1, reject) => {
    reject('break!')
    // throw new Error("에러 발생!");
    // new Promise((resolve2, reject) => {
    //     console.log("promise 1");
    //     setTimeout(resolve2, 1000);
    // }).then(resolve1);
}).then(() => {
    console.log("promise 2");
}).catch((e)=>console.log("error : ", e))

then을 써두고 promise를 return할거라고 예상했는데, return을 하지 않으면 어떻게하지?
그리고 로직이 중간에 끊겼는데 promise chain에서 어떻게 빠져나갈 수 있을까?

(() => {
    return null;   // <- error
    return new Promise((resolve, reject) => {
        console.log("promise 1");
        setTimeout(resolve, 1000);
    })
})().then(() => {
    console.log("promise 2");
});

 

promise를 빠져나가보자!

 

첫 번째 시도, Error를 날리자

하지만 catch에 안걸려서 fail

(() => {
    throw new Error("에러 발생!");
    return null;
    return new Promise((resolve, reject) => {
        console.log("promise 1");
        setTimeout(resolve, 1000);
    })
})().then(() => {
    console.log("promise 2");
}).catch((e)=>console.log("error : ", e))

 

두 번째 시도, Error를 날리는데 가장 위에 객체도 promise로 만들자

그러니 성공!

new Promise((resolve, reject) => {
    throw new Error("에러 발생!");
}).then(() => {
    console.log("promise 2");
}).catch((e)=>console.log("error : ", e))

 

마지막, 그럼 맨 처음 구조에다가 error를 날리는 부분을 합치면!

끝

new Promise((resolve1, reject) => {
    // throw new Error("에러 발생!");
    new Promise((resolve2, reject) => {
        console.log("promise 1");
        setTimeout(resolve2, 1000);
    }).then(resolve1);
}).then(() => {
    console.log("promise 2");
}).catch((e)=>console.log("error : ", e))

 

근데 생각해보니 일반 function이 아니라 promise를 사용할거면 그냥 reject를 쓰면 되는데...

new Promise((resolve1, reject) => {
    reject('break!')
    // throw new Error("에러 발생!");
    // new Promise((resolve2, reject) => {
    //     console.log("promise 1");
    //     setTimeout(resolve2, 1000);
    // }).then(resolve1);
}).then(() => {
    console.log("promise 2");
}).catch((e)=>console.log("error : ", e))

 

 

번외.

 promise에서 catch는 가장 가까운 것이 동작한다고 했는데

위 구조에서 속에 promise에서 error가 발생해도 밖에 promise의 catch에 걸릴까?

new Promise((resolve1, reject) => {
    new Promise((resolve2, reject) => {
        console.log("promise 1");
        throw new Error("에러 발생!");
        setTimeout(resolve2, 1000);
    }).then(resolve1);
}).then(() => {
    console.log("promise 2");
}).catch((e)=>console.log("error : ", e))

정답은 catch에 안걸리고 진짜 에러가 된다.

저작자표시 (새창열림)

'소프트웨어 > javascript' 카테고리의 다른 글

javascript로 linked list 만들기 (느낌대로)  (0) 2019.03.07
[javascript] clock 만들기  (0) 2016.06.07
    '소프트웨어/javascript' 카테고리의 다른 글
    • javascript로 linked list 만들기 (느낌대로)
    • [javascript] clock 만들기
    개발자_이훈규
    개발자_이훈규
    혼자 꽁양꽁양 개발하면서 놀아요~ - 노트같은 블로그

    티스토리툴바