返回值:jQueryajaxSuccess(handler(event, XMLHttpRequest, ajaxOptions))

注册一个事件处理函数,这个函数会在 Ajax 请求成功完成时被调用。这是一个 Ajax 事件

当 Ajax 请求成功完成后,jQuery 会触发 ajaxSuccess 事件。任何先前通过 .ajaxSuccess() 方法注册的事件处理函数都会在此刻被执行。

为了实际研究这个方法,我们构建一个简单的 Ajax load 请求:

<div class="trigger">Trigger</div>
<div class="result"></div>
<div class="log"></div>

可以把事件处理函数附加到任何元素上:

$('.log').ajaxSuccess(function() {
  $(this).text('Triggered ajaxSuccess handler.');
});

现在,我们可以用任意 jQuery 方法来发送一个 Ajax 请求,比如在 click 中发送一个请求:

$('.trigger').click(function() {
  $('.result').load('ajax/test.html');
});

当用户点击含有 trigger 的元素时,在 Ajax 请求成功后,就会显示日志信息。

注意: 由于 .ajaxSuccess() 是作为一个 jQuery 对象实例的方法来实现的,所以我们在回调函数中可以通过 this 关键字来指向原先所选中的元素。

无论是哪一个 Ajax 请求成功了,所有的 ajaxSuccess 处理函数都会被执行。如果有时必须区分出不同的请求,我们可以使用传递给事件处理函数的参数来识别不同的请求。每次 ajaxSuccess 事件处理函数执行时,都会传递一个事件对象,一个 jqXHR 对象(在 jQuery 1.5 之前, 是 XHR object),以及一个在请求创建时用的 settings 参数对象。其中 settings 参数对象就是调用 Ajax 请求时,传递给 $.ajax 方法的 settings 对象(有时候是在 jQuery 内部传递的,比如用 load 方法时,jQuery 内部也会调用 $.ajax 方法,并且构造并传递一个 settings 参数)。通过 settings 对象,我们就可以用来确定这是哪一个请求。比如说,我们可以限定某个回调函数仅仅处理某个特定的 URL:

注意: 可以通过 xhr.responseXMLxhr.responseText 属性,得到 ajax 返回的结果。

$('.log').ajaxSuccess(function(e, xhr, settings) {
  if (settings.url == 'ajax/test.html') {
    $(this).text('Triggered ajaxSuccess handler. The ajax response was:' 
                     + xhr.responseText );
  }
});

示例:

在 Ajax 请求成功后,显示一条信息。

jQuery 代码:
$("#msg").ajaxSuccess(function(evt, request, settings){
      $(this).append("<li>Successful Request!</li>");
      });