Promise 객체가 비동기 문제를 처리하는 방법을 설명하기 위해 jQuery의 $.Deferred 객체를 예로 들어 보겠습니다._jquery
Promise는 코드의 비동기 동작을 더욱 우아하게 만드는 추상화입니다. Promise는 작업 완료 여부에 관계없이 작업의 결과를 나타냅니다.
일부 최신 브라우저는 이미 Promise/A 표준을 따르는 기본 Promise 객체를 제공합니다. jQuery1.5에서는 $.Deferred(Promise 객체로 변환 가능)가 제공됩니다. 잘 알려진 많은 프레임워크도 Promise 개체를 제공합니다. Promise 객체는 이미 JavaScript에서 매우 중요한 패턴입니다. 비동기 문제를 해결하는 데 있어 Promise 개체가 보여주는 우아함은 바로 JavaScript에 필요한 것입니다. Promise 개체가 비동기 문제를 어떻게 처리하는지 알아보기 위해 jQuery의 $.Deferred 개체를 예로 들어 보겠습니다. $.Deferred 객체에 대해서는 jQuery 공식 홈페이지에서 확인하실 수 있으므로 여기서는 자세히 다루지 않겠습니다.
1. 비동기 작업 캡슐화
먼저 이미지 로딩을 예로 들어 다음 코드를 살펴보겠습니다.
//加载图片函数 var loadImg = function(url){ var img = new Image() , deferred = $.Deferred() ; img.src = url ; img.onload = function(){ //成功则触发deferred.resolve deferred.resolve( this ) ; } ; img.onerror = function(e){ //失败则触发deferred.reject deferred.reject( e ); } ; //返回promise对象 return deferred.promise() ; } ; //请求图片 var request = loadImg('http://r2.ykimg.com/0515000054AFFC2D6737B343930AFAD6') ; //请求成功 request.done(function(img){ //code }) ; //可以注册多个回调,当请求成功时,会按注册的顺序执行,fail和always也有此性质 request.done(function(img){ // code }); //请求失败 request.fail(function(){ // code }) ; //请求完毕 request.always(function(){ //code });
위 코드에서는 이미지 로딩 작업을 캡슐화하고 이를 $.Deferred에 위임한 다음 마지막으로 반환 약속을 생성합니다. 이 방법을 사용하는 것은 외부에 노출된 콜백을 사용하는 것보다 더 깔끔하고 명확합니다. 이를 수행하는 또 다른 더 중요한 이유는 약속의 연결입니다.
2. 인연을 약속합니다
Promise를 연결하는 방법을 알아보기 위해 위의 이미지를 로드하는 코드를 예로 들어 보겠습니다.
var request = loadImg('http://b1.hucdn.com/upload/item/1411/13/89613257775992_800x800.jpg') ; request.done(function(img){ //code }) ; //request连接别的promise之后返回的promise var request3 = request.then(function(img){ //request执行成功时 连接request1 var request1 = loadImg('http://b1.hucdn.com/upload/item/1410/19/29492535741725_800x800.jpg') ; return request1 ; },function(e){ //request执行失败时 连接request2 var request2 = loadImg('http://b1.hucdn.com/upload/item/1410/19/29492535741725_800x800.jpg') ; return request2 ; }); //request执行并且request1或request2成功执行时 request3.done(function(done){ //code }) ;
Promise 개체는 onResolve 및 onReject라는 두 개의 콜백을 허용하는 then 메서드를 제공합니다. 콜백에서 Promise를 반환하면 Promise 간의 연결이 완료될 수 있습니다. 이러한 방식으로 비동기 작업을 순차적으로 실행할 수 있습니다.
동시에 jQuery는 또 다른 연결 방법도 제공합니다. 코드를 참조하세요.
var request = loadImg('http://b1.hucdn.com/upload/item/1412/23/48188827139381_800x800.jpg') ; var request1 = loadImg('http://b1.hucdn.com/upload/item/1412/06/50258594673502_800x800.jpg') ; //通过$.when连接promise var request2 = $.when(request,request1) ; request2.done(function(img,img){ //code }) ;
jQuery는 n개의 Promise 객체를 매개변수로 받을 수 있는 $.when 함수를 제공합니다. Promise의 실행 결과를 함께 연결합니다. 이 접근 방식을 사용하면 여러 비동기 작업을 병렬로 실행할 수 있습니다.
3. 끝
여기 코드는 이미지 로드를 예로 들어 다른 비동기 작업에도 동일한 접근 방식을 적용할 수 있습니다. 예를 들어 jQuery에서 $.ajax 및 $.fn.animate를 호출하면 promise가 반환됩니다. 노드 측에서는 일부 비동기 작업(데이터베이스 읽기, 파일 읽기 등)도 약속으로 캡슐화될 수 있습니다. 그런 다음 여러 Promise에 병합 작업을 구현하여 직렬 또는 병렬로 실행합니다.
첨부: 지연 객체
Promise 객체를 변환하는 데 사용되는 것 외에도 deferred 자체도 매우 유용한 객체입니다. Promise 개체와 같은 메서드와 속성을 제공하는 것 외에도 알림 기능과 진행률 기능도 있습니다. 이 두 기능은 진행률 표시줄과 폭포 흐름을 구현할 때 매우 유용합니다.
진행률 표시줄을 구현할 때, 진행률 표시줄을 100%로 읽었을 때의 실행 타이밍과 실행 로직을 정의하는 데 Resolve 및 done 함수를 사용할 수 있습니다. 읽는 동안 진행률 표시줄의 시간입니다. 거부 및 실패 기능을 사용하여 진행률 읽기가 실패할 때 트리거 타이밍과 트리거 논리를 정의할 수 있습니다.
워터폴 흐름을 구현할 때 모든 데이터가 페이지에 로드되었을 때 분석 및 완료 기능을 사용하여 트리거 타이밍 및 트리거 로직을 정의할 수 있습니다. 알림 및 진행 함수를 사용하여 트리거 타이밍 및 트리거 시간을 정의할 수 있습니다. 폭포 흐름이 다음 페이지를 읽기 위한 것입니다.

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

동일한 ID로 배열 요소를 JavaScript의 하나의 객체로 병합하는 방법은 무엇입니까? 데이터를 처리 할 때 종종 동일한 ID를 가질 필요가 있습니다 ...

이 기사에서 시차 스크롤 및 요소 애니메이션 효과 실현에 대한 토론은 Shiseido 공식 웹 사이트 (https://www.shiseido.co.jp/sb/wonderland/)와 유사하게 달성하는 방법을 살펴볼 것입니다.

Console.log 출력의 차이의 근본 원인에 대한 심층적 인 논의. 이 기사에서는 Console.log 함수의 출력 결과의 차이점을 코드에서 분석하고 그에 따른 이유를 설명합니다. � ...

JavaScript를 배우는 것은 어렵지 않지만 어려운 일입니다. 1) 변수, 데이터 유형, 기능 등과 같은 기본 개념을 이해합니다. 2) 마스터 비동기 프로그래밍 및 이벤트 루프를 통해이를 구현하십시오. 3) DOM 운영을 사용하고 비동기 요청을 처리합니다. 4) 일반적인 실수를 피하고 디버깅 기술을 사용하십시오. 5) 성능을 최적화하고 모범 사례를 따르십시오.

프론트 엔드에서 VSCODE와 같은 패널 드래그 앤 드롭 조정 기능의 구현을 탐색하십시오. 프론트 엔드 개발에서 VSCODE와 같은 구현 방법 ...
