홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송
[jQuery 짤막팁] Ajax 를 순차적으로 여러개 불러오기
8년 전
jQuery 의 지연된 객체는 굉장히 유용한 기능을 제공하는데요. 이 중에서 가능한 기능이 바로 순차적으로 Ajax 를 요청해 적용하는 기법을 간단하게 구현 가능하다는 것입니다.
어떻게 돌아가냐면, 예를 들어, 3개의 페이지를 Ajax 로 불러옵니다. 그럼 이런 흐름으로 가고자 합니다.

page1.html 호출 -> 호출완료시 콜백 -> page2.html 호출 -> 호출완료시 콜백 -> page3.html 호출 -> 모든 페이지 호출완료 콜백

Ajax를 3개 한꺼번에 불러오고 모두 불러왔을 경우에 대한 대응부터 살펴보도록 하겠습니다. 간단합니다.

$.when($.ajax('page1.html'),$.ajax('page2.html'),$.ajax('page3.html')).then(function(){
    alert('3개 다불러왔어요~');
});

when 은 모든 지연된 객체를 받아내어, 그 지연된 객체의 resolve 이벤트를 모두 받아야만 then 이벤트가 적용되죠.

이걸 그대로 순차적으로 하고싶지만 그건 조금 어렵습니다.
하지만 그렇다고 해서 별도로 구현할 필요는 없습니다. jQuery 내장 기능으로도 충분히 강력하니까요.

먼저 구현 결과를 보시겠습니다.

var pages = ['page1.html', 'page2.html', 'page3.html']; //불러올 페이지 모음
var defer = new $.Deferred(); //새로운 빈 지연 객체를 초기화
var next = defer; //다음 지연 객체를 담을 변수

for(var i=0; i<pages.length; i++){
    next = next.then(function(){ //다음 지연 객체에 불러올 Ajax 호출 실시
        return $.ajax(pages[i]).done(function(text){
            // 여기에 페이지를 성공적으로 호출했을 때 콜백을 구현합니다.
            console.log('페이지 내용 : ' + text);
        }); //Ajax 객체는 메소드가 체인이기 때문에 반드시 변수에 담고 별도로 호출할 필요가 없습니다.
    });
}

next.then(function(){
    // 여기에 모든 페이지를 성공적으로 호출했을 때 콜백을 구현합니다.
    console.log('모든 페이지 호출 성공');
});

defer.resolve(); //명시적으로 resolve 를 호출하여 지연된 객체를 성공적으로 호출함을 알립니다.

어때요. 쉽죠?
지연된 객체는 then 호출 시 새로운 지연 이벤트를 생성합니다. 그래서 next 에 다음에 그 새로운 객체를 담죠. 이런 식으로 순차적으로 불러오는 방식입니다.

프로미즈 패턴의 위엄을 느낄 수 있는 간단한 예제가 되겠습니다.
물론 제이쿼리의 프로미즈와 ECMA 표준의 프로미즈는 조금 다른 양상을 띄고 있지만, 제이쿼리 또한 ECMA 표준에 따라가려 하기 때문에 차별화된다는 걱정은 안하셔도 됩니다.


참고 Source

var pages = ['page1.html', 'page2.html', 'page3.html']; //불러올 페이지 모음
var defer = new $.Deferred(); //새로운 빈 지연 객체를 초기화
var next = defer; //다음 지연 객체를 담을 변수

for(var i=0; i<pages.length; i++){
    next = next.then(function(){ //다음 지연 객체에 불러올 Ajax 호출 실시
        return $.ajax(pages[i]).done(function(text){
            // 여기에 페이지를 성공적으로 호출했을 때 콜백을 구현합니다.
            console.log('페이지 내용 : ' + text);
        }); //Ajax 객체는 메소드가 체인이기 때문에 반드시 변수에 담고 별도로 호출할 필요가 없습니다.
    });
}

next.then(function(){
    // 여기에 모든 페이지를 성공적으로 호출했을 때 콜백을 구현합니다.
    console.log('모든 페이지 호출 성공');
});
추천추천 : 384 추천 목록
번호 제목
3,035
 아이프레임(iframe) 비율 유지하면서 크기 조절하는 방법
3,034
 PHP 배열에서 무작위로 하나 뽑아주는 array rand() 함수
3,033
 PHP 정규식 정리
3,032
 PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
3,031
 php 크롤링 또는 파싱 함수, 정규식 모음
3,030
 제이쿼리 기본 명령어
3,029
 웹페이지 가로 모드세로 모드 인식하기
3,028
 모바일 웹 화면 강제 회전(가로모드 고정)
3,027
 [HTML5]에서 frameset 대체 방법과 iframe 속성
3,026
 HTML <Audio> 사용법
3,025
 윈도우10 시스템파일 손상 (초간단 오류 복구방법!!)
3,024
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
3,023
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
3,022
 CSS Layout 수평 & 수직 정렬
3,021
 여러 도메인들 간 쿠키 공유하기
3,020
 태그 사이에 있는 텍스트를 추출
3,019
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,018
 쿠키 생성,가져오기,삭제
3,017
 사용자 함수 모음
3,016
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,015
 [HTML5] <video> - DOM으로 제어하기
3,014
 HTML5 video 태그에서 영상 좌우반전
3,013
 PHP - 특정 태그 및 문자열 추출, 제거
3,012
 [PHP] define과 defined의 차이
3,011
 우클릭 완벽차단 스크립트
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.