DEFERRER
Last updated
Last updated
jQuery Deferred는 각각의 비동기식 처리에 Promise 객체를 연계하여 그 상태를 전파하는 것이다. 즉, promise를 구현한 jQuery 객체이다.
jQuery Deferred에서 각각의 비동기 처리를 Deferred객체로 wrapping한다. Deferred 객체는 상태를 가지고 있으며, 이는 비동기식 처리의 상태가 변경되는 시점에 특정 함수(resolve()
, reject()
)를 호출하여 Deferred 객체에 상태를 부여한다.
설명
pending
처리중
resolved
처리 성공
rejected
처리 실패
일반적인 처리 순서는 다음과 같다.
$.Deferred()
로 Deferred객체 생성
비동기 처리가 종료되면 Deferred 객체의 resolve()
or reject()
로 Deferred 객체의 state변경
promise()
로 Deferred 객체가 가지고 있는 Promise 객체를 반환한다. 반환된 객체는 Deferred 객체의 resolve()
or reject()
를 더 이상 사용할 수 없게되어 비동기 처리 상태를 보장할 수 있게된다.
연속된 복수의 비동기 처리를 병렬로 처리할 수 있다.
병렬처리 대상인 Promise가 모두 성공하면 $.when()
은 resolved Promise를 반환하고 한개라도 실패하면 rejected Promise를 반환한다.
다음과 같은 경우에 $.Deferred
를 사용하면 좋다.
데이터 접근 : 데이터 접근 API들을 $.Deferred
로 구현하는 것은 보통 좋은 디자인이다. Deferred API인 $.when
과 Deferred.pipe
는 비동기 서브쿼리들을 동기화하고 체인으로 연결하는데 매우 강력하다.
UI 애니매이션 : Deferred
로 애니매이션 함수들을 감싸는 것은 코드의 복잡도를 감소시키고 유연성을 증가시킬 수 있다. (일반적인 wrapper 함수도 큰 도움이 될 수 있다.)
UI 컴포넌트 표시 : 애플리케이션이 별도의 UI를 보여줄 필요가 있을 때, Deferred로 캡슐화된 컴포넌트들의 라이프 사이클을 가지는 것은 타이밍을 더 잘 조절할 수 있게 된다.
브라우저 비동기 API : 일반화 목적으로 브라우저 API 호출을 Deferred로 감싸는 것은 좋다.
캐싱
jQuery의 ajax 관련 함수들은 jQuery XMLHttpRequest(jqXHR) 객체를 반환하는데, 이 객체는 Deferred 객체와 유사하게 동작한다.