• 로그인
  • 장바구니에 상품이 없습니다.

home2 게시판 JavaScript, TS 게시판 promise btn 클릭 문제

promise btn 클릭 문제

3 글 보임 - 1 에서 3 까지 (총 3 중에서)
  • 글쓴이
  • #27351

    박땡땡
    참가자

    async function btnEvent(){
      const btnPromise = new Promise((resolve, reject) => {
        const btn = document.querySelector('#btn');
        btn.addEventListener('click', function(){
          const str = '성공했습니다.~_~'
          resolve(str);
        });
      });
        try {
          const result = await btnPromise;
          console.log(result);
        }
        catch {
          console.log('실패했어요 ㅠㅠ');
        }
    }
    btnEvent();

     

     

    선생님 저는 이렇게 했는데 ㅠㅠ 선생님 코드하고 다른데 잘못한걸까요?

    일단 성공했습니다가 뜨긴 하는데 

     

    저는 new Promise를 변수에 담아  async 바깥으로  빼고 넣고의 차이를 잘 모르겠어요..!

    선생님은 바깥으로 빼셨고, 저는 한데 묶은 함수에 async를  붙여줬는데.. 저처럼 했을 때의 문제점이 있나요?

    #27353

    박땡땡
    참가자

    +그리고 원래 클릭이벤트는 클릭할때마다 발생하는 것이 아닌가요??

    제가 중복 클릭해도 콘솔창엔 성공했습니다 문구가 한번만 뜨는데 왜 그럴까요??

    #27373

    codingapple
    키 마스터

    별차이는 없어보입니다 async function 은 그 자리에 promise가 남아서 간단하게 new Promise 대용으로 쓰는 것일 뿐입니다 

    promise는 1번 성공하거나 실패하거나 하면 끝입니다 2회 성공 그런건 없습니다 

3 글 보임 - 1 에서 3 까지 (총 3 중에서)
  • 답변은 로그인 후 가능합니다.

About

현재 월 700명 신규수강중입니다.

  (09:00~20:00) 빠른 상담은 카톡 플러스친구 코딩애플 (링크)
  admin@codingapple.com
  이용약관
ⓒ Codingapple, 강의 예제, 영상 복제 금지
top

© Codingapple, All rights reserved. 슈퍼로켓 에듀케이션 / 서울특별시 강동구 고덕로 19길 30 / 사업자등록번호 : 212-26-14752 온라인 교육학원업 / 통신판매업신고번호 : 제 2017-서울강동-0002 호 / 개인정보관리자 : 박종흠