ajaxSend()

在Ajax请求发送之前绑定一个要执行的函数,这是一个 Ajax Event.

.ajaxSend ( handler )

handler 。类型: Function ( Event event , jqXHR jqXHR , PlainObject ajaxOptions )。被调用的函数。

每当一个Ajax请求即将发送,jQuery就会触发 ajaxSend 事件,在这个时间点所有处理函数都会使用 .ajaxSend() 方法注册并执行。

观察这种方法,建立一个基本的Ajax加载请求:

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

在document上绑定事件处理器:

$(document).ajaxSend(function() {
  $( ".log" ).text( "Triggered ajaxSend handler." );
});

现在,我们可以使用任何的jQuery方法构建一个Ajax请求:

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

当我们点击class为 trigger 的元素并且Ajax请求即将开始,这个信息就会显示。

ajaxSend 无论要发送什么Ajax请求,都将调用所有处理程序。如果我们必须区分不同的请求,我们可以使参数传递给这个处理器。每次 ajaxSend 处理器执行,它传递事件对象, jqXHR 对象(在 jQuery 1.4中是 XMLHttpRequest 对象),和用来创建请求的设置(settings object)对象。如果请求失败,因为JavaScript抛出一个异常,并且作为第四个参数的异常对象被传递给处理程序。举个例子,我们能限制我们的回调到只处理事件处理某一特定的URL:

$(document).ajaxSend(function(event, jqxhr, settings) {
  if ( settings.url == "ajax/test" ) {
    $( ".log" ).text( "Triggered ajaxSend handler." );
  }
});

其他注意事项:

  • 在jQuery1.9中,jQuery全局AJAX事件的所有处理程序,包括哪些 .ajaxSend() 添加的方法, 必须 附加到 document 上。
  • 如果 $.ajax() $.ajaxSetup() 调用时, global 选项设置为 false .ajaxSend() 将不会触发。

例子

当Ajax请求即将发送前显示一个信息。

$(document).ajaxSend(function(event, request, settings) {
    $( "#msg" ).append( "<li>Starting request at " + settings.url + "</li>" );
});

下篇: ajaxStart()