홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송
운.영.자.1대1.상담
온라이브 음악방송
음악방송 앱 다운로드
보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
[jQuery 짤막팁] Ajax 를 순차적으로 여러개 불러오기
7년 전
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('모든 페이지 호출 성공');
});
추천추천 : 363 추천 목록
번호 제목
3,025
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
3,024
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
3,023
 CSS Layout 수평 & 수직 정렬
3,022
 여러 도메인들 간 쿠키 공유하기
3,021
 태그 사이에 있는 텍스트를 추출
3,020
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,019
 쿠키 생성,가져오기,삭제
3,018
 사용자 함수 모음
3,017
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,016
 [HTML5] <video> - DOM으로 제어하기
3,015
 HTML5 video 태그에서 영상 좌우반전
3,014
 PHP - 특정 태그 및 문자열 추출, 제거
3,013
 [PHP] define과 defined의 차이
3,012
 우클릭 완벽차단 스크립트
3,011
 iframe 높이 100% 맞추기
3,010
 curl 함수를 이용한 HTTP REFERER 변경
3,009
 윈도우10 시스템 파일 및 Dism 검사
3,008
 텍스트 줄바꿈, 글자자르기 CSS
3,007
 jQuery Mobile에서 유용한 코드 10가지.
3,006
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,005
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,004
 [jQuery] jQuery Quick API
3,003
 [ transition ] 링크 hover 색상 변화 속도 조절
3,002
 PHP 5.3.0 에서 사라진 함수들 대체
3,001
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
목록
환상의뽕짝카페
트로트티비
뽕짝아가씨
트롯맘
종합성인가요방
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
POP TOP BEST

최신인기가요특집
추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.