`setTimeout` 함수를 약속으로 바꾸는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-11-25 01:42:18
원래의
123명이 탐색했습니다.

How to Turn a `setTimeout` Function into a Promise?

setTimeout을 Promise로 바꾸는 방법

setTimeout과 같이 아무것도 반환하지 않는 함수에 대한 Promise를 생성하는 작업입니다. 처음에는 어려울 수 있습니다. 이 개념을 이해하기 위해 수정된 코드 샘플을 참조해 보겠습니다.

<br>function async(콜백){</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">setTimeout(function(){
    callback();
}, 5000);
로그인 후 복사

}

async(function(){

console.log('async called back');
로그인 후 복사

});

우리의 목표는 setTimeout 콜백이 실행되면 비동기가 반환될 수 있다는 약속을 생성하는 것입니다. Ready.

Promise가 포함된 기본 지연

기본 Promise를 사용하면 다음과 같이 나중에 호출되는 함수를 만들 수 있습니다.

 <br>나중에 기능(지연) {</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">return new Promise(function(resolve) {
    setTimeout(resolve, delay);
});
로그인 후 복사

}

이 함수는 밀리초 단위의 지연 시간을 가지며 지연 시간이 만료된 후 해결되는 Promise를 반환합니다.

< ;h3>값이 있는 기본 지연

수정하려면 나중에 해상도 값을 전달하도록 허용하려면 setTimeout 콜백이 값을 인수로 수신하는지 확인해야 합니다. setTimeout에 추가 인수 제공을 지원하는 브라우저의 경우 다음 코드를 사용할 수 있습니다.

<br>function later(delay, value) {</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">return new Promise(function(resolve) {
    setTimeout(resolve, delay, value);
});
로그인 후 복사

}

이 코드는 값이 콜백에 전달되고 이후에 promise.

값이 있는 취소 가능한 지연

타임아웃을 취소하는 기능을 제공하려는 경우 취소 메소드가 있는 객체를 생성하고 약속의 접근자. 취소 메소드가 호출되면 시간 초과를 지우고 약속을 거부합니다.

<br>const later = (delay, value) => {</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">let timer = 0;
let reject = null;
const promise = new Promise((resolve, _reject) => {
    reject = _reject;
    timer = setTimeout(resolve, delay, value);
});
return {
    get promise() { return promise; },
    cancel() {
        if (timer) {
            clearTimeout(timer);
            timer = 0;
            reject();
            reject = null;
        }
    }
};
로그인 후 복사

};

이 접근 방식은 보류 중인 제한 시간을 취소하고 관련 Promise를 거부하는 방법을 제공합니다.

위 내용은 `setTimeout` 함수를 약속으로 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
이전 기사:내가 React에서 싫어하는 5가지 점(및 이를 극복하는 방법) 다음 기사:Internet Explorer 호환성을 위해 JavaScript의 `Array.prototype.indexOf()`를 어떻게 확장할 수 있습니까?
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
최신 이슈
관련 주제
더>
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿