Language/JavaScript, TypeScript2 [JS/TS] Promise와 async/await [참조] 동기 / 비동기Promise정의비동기 함수의 결과를 담고 있는 객체동기적으로 순서대로 불러야 하는 코드가 있을 때, 사용하는 함수계속 호출하면 코드가 복잡해지고 에러 처리가 어려워지는 콜백의 단점을 보완함세 개의 상태Pending: 비동기 함수가 시작하지 않은 상태Fulfilled: 비동기 함수가 성공적으로 완료된 상태Rejected: 비동기 함수가 실패한 상태Promise가 대기 상태에서 상태가 바뀌면 then(), catch() 함수를 사용하여 각각 성공과 실패 Promise를 처리할 수 있다.하지만, then() 체인을 길게 이어나가면 콜백과 마찬가지로 가독성이 떨어지고 에러 파악이 어려워진다.async/awaitasync 정의함수 앞에 붙여 비동기 함수임을 명시한다.항상 Promise 객.. 2025. 1. 23. [JS/TS] Trouble Shooting: 컴파일과 런타임 환경 NestJS로 간단한 게시판을 제작하며 CRUD기능을 구현하고 있었다. 그러던 중 Delete기능의 예외 처리를 하는 과정에서 문제가 발생했다. 위 사진들처럼 해당하는 id가 있음에도 불구하고, id를 인식하지 못하였다. 여기저기 검색도 해보고 코드도 수정해봤지만 결국 해결을 못했고,GPT에게 물어본 결과 아래 코드처럼 id 파라미터를 강제로 형변환 하는 해결책을 제시해 주었고, 문제는 해결되었다. 여기서 궁금증이 생겼다.board.id 의 타입도 사전에 number로 지정해 주었고, id 파라미터의 타입도 number로 명시적으로 지정해 주었는데 왜 타입이 string으로 바뀌는건지 이해가 가지 않았다. 여기저기 찾아보며 도출한 결과는 아래와 같다.TypeScript 코드는 컴파일환경에서 JavaS.. 2025. 1. 22. 이전 1 다음