"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 최적의 제어를 위해 Ajax 요청 순서를 지정하는 방법은 무엇입니까?

최적의 제어를 위해 Ajax 요청 순서를 지정하는 방법은 무엇입니까?

2024-11-03에 게시됨
검색:209

How to Sequence Ajax Requests for Optimal Control?

Ajax 요청 순서 지정

컬렉션을 반복하고 각 요소에 대해 개별 Ajax 호출을 수행할 때 순서를 제어하는 ​​것이 중요합니다. 서버 과부하 및 브라우저 정지. 사용자 정의 반복자를 사용할 수 있지만 더 우아한 솔루션을 사용할 수 있습니다.

jQuery 1.5

jQuery 1.5 이상에서는 $.ajaxQueue() 플러그인이 $.ajaxQueue() 플러그인을 활용합니다. .Deferred, $.queue() 및 $.ajax()는 요청 순서를 관리하고 요청 시 해결되는 약속을 제공합니다. 완료.

구현:

var jqXHR,
    dfd = $.Deferred(),
    promise = dfd.promise();

ajaxQueue.queue( doRequest );

promise.abort = function( statusText ) {
  if ( jqXHR ) {
    return jqXHR.abort( statusText );
  }
  var queue = ajaxQueue.queue(),
      index = $.inArray( doRequest, queue );
  if ( index > -1 ) {
    queue.splice( index, 1 );
  }
  dfd.rejectWith( ajaxOpts.context || ajaxOpts,
    [ promise, statusText, "" ] );
  return promise;
};

function doRequest( next ) {
  jqXHR = $.ajax( ajaxOpts )
    .done( dfd.resolve )
    .fail( dfd.reject )
    .then( next, next );
}

return promise;

};

})(jQuery);

jQuery 1.4

jQuery 1.4의 경우 애니메이션 큐를 활용하여 사용자 정의 "큐"를 생성할 수 있습니다. 아직 실행되지 않은 경우 jQuery의 'fx' 대기열을 사용하여 대기열의 첫 번째 요청을 자동으로 시작하는 자체 $.ajaxQueue() 플러그인을 만들 수도 있습니다.

구현:

var oldComplete = ajaxOpts.complete;

ajaxQueue.queue(function(next) {
  ajaxOpts.complete = function() {
    if (oldComplete) oldComplete.apply(this, arguments);
    next();
  };
  $.ajax(ajaxOpts);
});

};

})(jQuery);

예:

url: '/echo/html/',
data: {html : "[" idx "] " $(this).html()},
type: 'POST',
success: function(data) {
  $("#output").append($("<li>", { html: data }));
}

});
});

이렇게 하면 각 Ajax 요청이 순차적으로 실행되어 서버 로드를 적절하게 처리하고 브라우저 응답성을 유지할 수 있습니다. .

릴리스 선언문 이 글은 1729396281에서 재인쇄되었습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3