웹 프론트엔드 JS 튜토리얼 jQuery는 page_jquery에서 모든 Ajax 요청을 모니터링하는 방법을 구현합니다.

jQuery는 page_jquery에서 모든 Ajax 요청을 모니터링하는 방법을 구현합니다.

May 16, 2016 pm 03:26 PM
아약스 요청 jquery 감시 장치

이 기사의 예에서는 jQuery가 페이지의 모든 Ajax 요청 모니터링을 구현하는 방법을 설명합니다. 참고하실 수 있도록 모든 사람과 공유하세요. 자세한 내용은 다음과 같습니다.

이러한 문제에 직면한 적이 있습니까? 페이지가 다른 조치를 취하기 전에 성공하기를 바라면서 두 개의 Ajax 요청을 시작합니까?

생각하기 쉬운 해결책은 다른 하나를 시작하기 전에 하나가 끝날 때까지 기다리는 것입니다. 이 프로세스는 콜백 함수를 사용하여 완료됩니다.

그런데 Ajax 요청 코드 중 하나를 직접 작성하지 않았고 변경할 수 없는 경우에는 어떻게 해야 하나요?

즉, 특정 URL 요청이 언제 끝나는지 알고 싶고 다른 요청은 걱정하지 않으려는 것입니다.

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
  </head>
  <body>
    <p id="test"></p>
  </body>
  <script src="js/jquery-1.11.0.min.js"></script>
  <!--首先在页面引入jquery的后面,紧接着以下代码:-->
  <script>
    //前提:所有ajax请求都是用jquery的$.ajax发起的,而非原生的XHR;
    var ajaxBack = $.ajax;
    var ajaxCount = 0;
    var allAjaxDone = function(){$('#test').append('all done!<br>');} //一行代码,就可以知道所有ajax请求什么时候结束
    //由于get/post/getJSON等,最后还是调用到ajax,因此只要改ajax函数即可
    $.ajax = function(setting){
      ajaxCount++;
      var cb = setting.complete;
      setting.complete = function(){
        if($.isFunction(cb)){cb.apply(setting.context, arguments);}
        ajaxCount--;
        if(ajaxCount==0 && $.isFunction(allAjaxDone)){
          allAjaxDone();
        }
      }
      ajaxBack(setting);
    }
  </script>
  <!--以下是别人的script-->
  <script>
    $.ajax({url: 'js/jquery-1.11.0.min.js', success: function(recv){$('#test').append('别人的ajax请求1,done<br>')}});
  </script>
  <script>
    $.get('css/main.css', null, function(recv){$('#test').append('别人的get请求,done<br>')});
  </script>
  <script>
    $.post('css/main.css', null, function(recv){$('#test').append('别人的post请求,done<br>')});
  </script>
</html>

로그인 후 복사

기타 관련 기능:

$.ajax:

오류: 오류가 발생할 때 호출되며 잘못된 요청을 보고하는 데 사용할 수 있습니다.
완료: 성공 또는 실패에 관계없이 호출됩니다

높은 버전:

$.약속
$.언제

이 기사가 jQuery 프로그래밍에 종사하는 모든 사람에게 도움이 되기를 바랍니다.

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

jQuery에서 PUT 요청 방법을 사용하는 방법은 무엇입니까? jQuery에서 PUT 요청 방법을 사용하는 방법은 무엇입니까? Feb 28, 2024 pm 03:12 PM

jQuery에서 PUT 요청 방법을 사용하는 방법은 무엇입니까?

jQuery를 사용하여 요소의 높이 속성을 제거하는 방법은 무엇입니까? jQuery를 사용하여 요소의 높이 속성을 제거하는 방법은 무엇입니까? Feb 28, 2024 am 08:39 AM

jQuery를 사용하여 요소의 높이 속성을 제거하는 방법은 무엇입니까?

jQuery 팁: 페이지에 있는 모든 태그의 텍스트를 빠르게 수정하세요. jQuery 팁: 페이지에 있는 모든 태그의 텍스트를 빠르게 수정하세요. Feb 28, 2024 pm 09:06 PM

jQuery 팁: 페이지에 있는 모든 태그의 텍스트를 빠르게 수정하세요.

jQuery를 사용하여 모든 태그의 텍스트 내용 수정 jQuery를 사용하여 모든 태그의 텍스트 내용 수정 Feb 28, 2024 pm 05:42 PM

jQuery를 사용하여 모든 태그의 텍스트 내용 수정

Laravel 모니터링 오류: 애플리케이션 안정성 향상 Laravel 모니터링 오류: 애플리케이션 안정성 향상 Mar 06, 2024 pm 04:48 PM

Laravel 모니터링 오류: 애플리케이션 안정성 향상

해바라기 리모콘이 모니터링되나요? 해바라기 리모콘은 개인정보를 공개하나요? 해바라기 리모콘이 모니터링되나요? 해바라기 리모콘은 개인정보를 공개하나요? Mar 15, 2024 pm 05:28 PM

해바라기 리모콘이 모니터링되나요? 해바라기 리모콘은 개인정보를 공개하나요?

jQuery에서 eq의 역할 및 적용 시나리오 이해 jQuery에서 eq의 역할 및 적용 시나리오 이해 Feb 28, 2024 pm 01:15 PM

jQuery에서 eq의 역할 및 적용 시나리오 이해

jQuery 요소에 특정 속성이 있는지 어떻게 알 수 있나요? jQuery 요소에 특정 속성이 있는지 어떻게 알 수 있나요? Feb 29, 2024 am 09:03 AM

jQuery 요소에 특정 속성이 있는지 어떻게 알 수 있나요?

See all articles