zoukankan      html  css  js  c++  java
  • ajax第三步

    ajaxSend()函数用于设置当AJAX请求即将被发送时执行的回调函数。

    这是一个全局AJAX事件函数,用于为任何AJAX请求的ajaxSend事件绑定事件处理函数。当AJAX请求即将被发送时,将触发ajaxSend事件,并执行绑定的事件处理函数。

    该函数必须在jQuery对象实例上调用,ajaxSend()将为每个匹配元素的ajaxSend事件绑定处理函数。当AJAX请求即将被发送完成后,所有匹配元素上的处理函数都将被触发执行。事件处理函数内的this将指向当前DOM元素。

    你可以在同一元素多次调用该函数,从而绑定多个事件处理函数。触发ajaxSend事件时,jQuery会按照绑定的先后顺序依次执行绑定的事件处理函数。

    jQuery 1.8开始,该函数只能document对象的ajaxSend事件绑定处理函数,为其他元素绑定的事件处理函数不会起作用。

    如果在jQuery.ajax()jQuery.ajaxSetup()中将选项参数global设为false,可以禁止该AJAX请求触发全局的AJAX事件。

    该函数属于jQuery对象(实例)。

    语法

    jQuery 1.0 新增该函数。

    jQueryObject.ajaxSend( handler )

    参数

    参数描述
    handler Function类型触发该事件时,需要执行的事件处理函数。

    回调函数handler有3个参数:其一是表示当前事件的Event对象,其二是发送当前AJAX请求的jqXHR对象,其三是包含为本次AJAX请求设置的所有参数选项(包括无需指定的默认参数选项)的Object对象。

    jqXHR对象就是经过jQuery封装的XMLHttpRequest对象(保留了其大多数属性和方法)。

    返回值

    ajaxSend()函数的返回值为jQuery类型,返回当前jQuery对象本身。

    示例&说明

    请参考以下HTML示例代码:

    <div id="content1">CodePlayer</div>
    <div id="content2">专注于编程开发技术分享</div>
    <div id="content3">http://www.365mini.com</div>

    以下是与ajaxSend()函数相关的jQuery示例代码,以演示ajaxSend()函数的具体用法:

    以下代码请基于1.8之前版本的jQuery来运行(请注意,通过ajaxSend()设置的全局事件处理函数与通过$.ajax()beforeSend选项设置的局部事件处理函数,它们的参数是不同的)。

    //当前 jQuery版本:1.7.2 (必须是1.8之前的版本)

    $("div").ajaxSend( function(event, jqXHR, options){
        alert("处理函数1: 当前元素的id为" + this.id + ",请求的url为" + options.url);
    } );

    $("div").ajaxSend( function(event, jqXHR, options){
        alert("处理函数2:请求方式为" + options.type);
    } );


    // 执行该AJAX请求,会弹出6次对话框
    // 因为当前页面有3个div元素,我们为每个div元素绑定了2个事件处理函数
    $.ajax( {
        url: "index.html"
    } );


    // 执行该AJAX请求,会弹出7次对话框
    // 因为当前页面有3个div元素,我们为每个div元素绑定了2个事件处理函数
    // 此外$.ajax()自己通过beforeSend选项绑定了一个局部的ajaxSend事件处理函数,它会执行一次

    // 因此总共弹出7次对话框
    $.ajax( {
        url: "myurl" ,
        beforeSend: function(jqXHR, options){
           alert( "即将开始发送!" );
           // return false; // 如果返回false,可以取消本次请求
        }
    } );

    如果当前jQuery为1.8及以上版本,上述jQuery代码总共只会弹出一次对话框。因为从jQuery 1.8开始,ajaxSend事件的处理函数必须绑定到document对象上才能生效。

    因此,不论当前jQuery为何版本,如果不是特殊需求,我们都应该将ajaxSend事件的处理函数绑定到document对象上。

    $(document).ajaxSend( function(event, jqXHR, options){
        alert("处理函数1: 当前元素的id为" + this.id + ",请求的url为" + options.url);
    } );

    $(document).ajaxSend( function(event, jqXHR, options){
        alert("处理函数2:请求方式为" + options.type);
    } );


    // 执行该AJAX请求,会弹出2次对话框
    // 因为document对象上绑定了2个事件处理函数
    $.ajax( {
        url: "index.html"
    } );


    // 执行该AJAX请求,会弹出3次对话框
    // 因为$.ajax()自己通过beforeSend选项绑定了一个局部的ajaxSend事件处理函数,它会执行一次
    // 我们还通过ajaxSend()额外绑定了两个事件处理函数,会再弹出2次
    $.ajax( {
        url: "myurl" ,
        // global: false , // 可以禁止触发全局的Ajax事件
        beforeSend: function(jqXHR, options){
            alert( "即将开始发送!" );
            // return false; // 如果返回false,可以取消本次请求
        }
    } );
  • 相关阅读:
    ValueError: source code string cannot contain null bytes
    django.db.utils.OperationalError: (2003, "Can't connect to MySQL server on 'localhost' ([Errno 11001] No address found)")
    数据库索引
    Python深拷贝与浅拷贝
    ascii、unicode、utf-8、gbk
    map、reduce、filter 的用法
    TCP / UDP的区别
    男神鹏:SyntaxError: invalid character in identifier 报错!!
    男神鹏:机器学习之混淆矩阵的理解
    男神鹏:Visual Studio Code 解决红色波浪线操作
  • 原文地址:https://www.cnblogs.com/KLYY/p/6548605.html
Copyright © 2011-2022 走看看