setTimeout()을 Promise Chain에 올바르게 통합하는 방법은 무엇입니까?
Promise Chains에서 setTimeout() 사용
Promise로 작업할 때 Promise Chain 내에서 비동기 작업을 처리하는 방법을 이해하는 것이 중요합니다. 주어진 코드 조각에서 의도는 약속 체인의 후속 요청 실행을 지연시키는 것입니다. 그러나 .then() 핸들러 내에서 직접 setTimeout()을 사용하면 문제가 발생할 수 있습니다.
setTimeout()이 실패하는 이유
코드에서 setTimeout()은 두 번째 요청의 .then() 핸들러 내에서 사용됩니다. 그러나 이 접근 방식은 .then() 핸들러의 반환 값이 약속이 아니기 때문에 약속 체인을 깨뜨립니다. 연결하려는 Promise가 포함된 setTimeout() 콜백은 자체 컨텍스트 외부에서는 액세스할 수 없습니다.
지연 함수를 사용하는 솔루션
Promise 체인을 유지하려면 , 약속을 반환하는 별도의 지연 함수를 생성할 수 있습니다:
<code class="javascript">function delay(t, val) { return new Promise(resolve => setTimeout(resolve, t, val)); }</code>
그런 다음 약속 체인에서 지연 함수를 사용합니다.
<code class="javascript">return delay(1000).then(function() { return getLinks(globalObj["two"] + ".txt"); });</code>
이것은 .then에서 약속을 반환합니다. () 핸들러는 후속 요청의 실행이 지연되도록 합니다.
Promise.prototype.delay를 사용하는 대안
또 다른 옵션은 다음을 사용하여 Promise 객체를 확장하는 것입니다. 지연 메서드:
<code class="javascript">Promise.prototype.delay = function(t) { return this.then(function(val) { return delay(t, val); }); }</code>
이 메서드를 사용하면 Promise에서 .delay()를 직접 호출할 수 있습니다.
<code class="javascript">Promise.resolve("hello").delay(500).then(function(val) { console.log(val); });</code>
두 접근 방식 모두 Promise 체인이 올바르게 유지되고 후속 요청은 지정된 지연 후에 실행됩니다.
위 내용은 setTimeout()을 Promise Chain에 올바르게 통합하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

microfrontendssolvesscalingchalingchalengesinlargeteams는 독립적 인 developmentanddeployment.1) chooseeanintegrationstrategy : usemodulefederation inwebpack5forruntimeloadingandtrueindence, build-timeintegrationforsimplesetups, oriframes/webcomponents

TypeScript의 고급 조건 유형은 TextEndsu? x : y 구문을 통해 유형간에 논리적 판단을 구현합니다. 핵심 기능은 분산 조건 유형, 유추 유형 추론 및 복잡한 유형 도구의 구성에 반영됩니다. 1. 조건부 유형은 베어 유형 매개 변수에 분산되며 문자열 [] | 번호 []를 얻기 위해 ToArray와 같이 조인트 유형을 자동으로 분할 할 수 있습니다. 2. 분포를 사용하여 필터링 및 추출 도구를 구축하기 위해 : textendsu를 통해 유형을 제외하고 textendu? t : never 및 null/undefined를 통해 공통점을 추출합니다. 3

가변성-점장, 캔버스 서명, hoistedwithundwithunded, andattachedtotheglobalwindowobject; 2. letandconstareBlock- 스코핑, letlallowingEassignmentandSconstnotallowingit, theConstoBjectScanHaveMutableproperties;

옵션 체인 (?.) injavascriptSafelyAccessesNestEdEsTeDeRningUndUndUndUndErningUndErningDefinePantOftOfTHainInullOrUndErord, 1.ItAllOwsSafeAccessTodeepLynestedObjectProperties, SuchAsUser.Profile?

이 기사에서는 더블 체코 퍼즐 게임에 대한 솔루 가능한 퍼즐을 자동으로 생성하는 방법을 심도있게 살펴 봅니다. 우리는 경계 정보, 색상 및 상태를 포함하는 2D 그리드를 기반으로 한 효율적인 데이터 구조를 소개합니다. 이를 바탕으로, 우리는 재귀 블록 인식 알고리즘 (깊이 우선 검색과 유사)과 반복 퍼즐 생성 프로세스에 통합하여 생성 된 퍼즐이 게임의 규칙을 충족시키고 용서가되도록하는 방법에 대해 자세히 설명 할 것입니다. 이 기사는 샘플 코드를 제공하고 생성 프로세스에서 주요 고려 사항 및 최적화 전략에 대해 논의합니다.

JavaScript를 사용하여 DOM 요소에서 CSS 클래스를 제거하는 가장 일반적이고 권장되는 방법은 클래스리스트 속성의 remove () 메소드를 통한 것입니다. 1. Element.classList.remove ( 'ClassName')를 사용하여 단일 또는 여러 클래스를 안전하게 삭제하면 클래스가 존재하지 않더라도 오류가보고되지 않습니다. 2. 대안적인 방법은 ClassName 속성을 직접 작동하고 문자열 교체로 클래스를 제거하는 것이지만, 정기적으로 일치하거나 부적절한 공간 처리로 인해 문제를 일으킬 수 있으므로 권장되지 않습니다. 3. 먼저 클래스가 존재하는지 판단 한 다음 ementcle.classlist.contains ()를 통해 삭제할 수 있지만 일반적으로 필요하지 않습니다. 4. 클래스리스트

JavaScript의 클래스 구문은 프로토 타입에 의해 상속 된 구문 설탕입니다. 1. 클래스로 정의 된 클래스는 본질적으로 기능이며 방법은 프로토 타입에 추가됩니다. 2. 인스턴스는 프로토 타입 체인을 통해 방법을 찾습니다. 3. 정적 방법은 클래스 자체에 속합니다. 4. 프로토 타입 체인을 통해 상속을 확장하고 기본 층은 여전히 프로토 타입 메커니즘을 사용합니다. 클래스는 JavaScript 프로토 타입 상속의 본질을 바꾸지 않았습니다.

먼저 NPXStoryBookInit을 사용하여 React Project에서 스토리 북을 설치하고 구성하고 NPMRUNSTORYBOOK을 실행하여 로컬 개발 서버를 시작하십시오. 2. 함수 또는 유형에 따라 구성 요소 파일 구조를 구성하고 각 구성 요소 디렉토리에서 다른 상태를 정의하기 위해 해당 .stories.js 파일을 만듭니다. 3. Storybook의 Args 및 Controls 시스템을 사용하여 다양한 대화식 상태의 테스트를 용이하게하기 위해 동적 속성 조정을 달성합니다. 4. MDX 파일을 사용하여 설계 사양, 접근성 지침 등이 포함 된 풍부한 텍스트 문서를 작성하고 구성을 통해 MDX로드를 지원합니다. 5. Theme.js를 통해 디자인 토큰을 정의하고 preview.js를 사용하십시오.
