jQuery ajax:Baidu ajax

你没有看错标题,本文的确是在讲Baidu ajax,不过是很久很久以前的版本了。

由于jQuery ajax 模块有800+行,而核心函数jQuery.ajax就有380+行,直接分析这段代码很容易被代码逻辑弄晕。

所以 我们先分析一段简单的ajax代码,来自早期的百度七巧板项目。

通过这个来先复习一遍ajax的知识。

baidu.ajax.request分离版

/**
 * 发送一个ajax请求
 * @author: allstar, erik, berg
 * @name ajax.request
 * @function
 * @grammar ajax.request(url[, options])
 * @param {string}     url 发送请求的url
 * @param {Object}     options 发送请求的选项参数
 * @config {String}     [method]             请求发送的类型。默认为GET
 * @config {Boolean}  [async]             是否异步请求。默认为true(异步)
 * @config {String}     [data]                 需要发送的数据。如果是GET请求的话,不需要这个属性
 * @config {Object}     [headers]             要设置的http request header
 * @config {number}   [timeout]       超时时间,单位ms
 * @config {String}     [username]             用户名
 * @config {String}     [password]             密码
 * @config {Function} [onsuccess]         请求成功时触发,function(XMLHttpRequest xhr, string 

responseText)。
 * @config {Function} [onfailure]         请求失败时触发,function(XMLHttpRequest xhr)。
 * @config {Function} [onbeforerequest]    发送请求之前触发,function(XMLHttpRequest xhr)。
 *
 * @meta standard
 * @see ajax.get,ajax.post
 *
 * @returns {XMLHttpRequest} 发送请求的XMLHttpRequest对象
 */
var ajax = {};
ajax.request = function(url,options,type){
        // 是否需要异步
    var async = options.async||true,
        // 用户名、密码
        username = options.username||"",
        password = options.password||"",
        // 需要传输的数据
        data = options.data||"",
        // GET还是POST
        method = (options.method||"GET").toUpperCase(),
        // 请求头
        headers = options.headers||{},
        // 事件处理函数表
        eventHandler = {},
        // 请求数据类型
        dataType = type||"string";//xml||string

    function stateChangeHandler(){
        // 看看是否已经准备好了
        if(xhr.readyState == 4){
            // 得到xhr当前状态
            var sta = xhr.status;
            // 判断是否成功
            if(sta == 200||sta == 304){
                // 成功则触发成功
                fire("success");
            }else{
                // 失败则触发失败
                fire("failure");
            }

            // 清除绑定
            window.setTimeout(function(){
                xhr.onreadystatechange= new Function();
                if (async){
                    xhr = null;
                }
            },0);
        }
    }

    function fire(type){
        // 把type变成ontype
        type = "on"+type;
        // 在事件处理器表中找到对应事件的处理函数
        var handler = eventHandler[type];
        // 如果函数存在,则
        if(handler){
            // 不成功的话
            if(type != "onsuccess"){
                handler(xhr);
            // 成功了
            }else{
                // 则根据dataType返回不同的数据
                handler(xhr,dataType!="xml"?xhr.responseText:xhr.responseXML);
            }
        }
    }

    // 组装eventHandler
    for(var key in options){
        eventHandler[key] = options[key];
    }

    // 新建一个XMLHttpRequest对象
    var xhr = new XMLHttpRequest();
    // 如果方法是GET,则把数据组装到url中
    if(method == "GET"){
        url += (url.indexOf("?")>=0)?"&":"?";
        url += data;
        // 清空data
        data = null;
    }
    // 如果是异步
    if (async){
        // 绑定readystatechange的处理器
        xhr.onreadystatechange = stateChangeHandler;
    }
    // 看看是否需要输入密码
    if(username){
        xhr.open(method,url,async,username,passowrd);
    }else{
        xhr.open(method,url,async);
    }
    // 如果是POST
    if(method == "POST"){
        // 设置一下请求头
        xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    }
    // 把options中的请求头信息全部设置进去
    for(var key in headers){
        xhr.setRequestHeader(name,headers[key])
    }
    // 触发事件beforerequest
    fire("beforerequest");
    // 发送数据
    xhr.send(data);

    // 如果不是异步
    if (!async){
        // 则直接运行stateChangeHandler来处理数据
        stateChangeHandler();
    }

    return xhr;
}

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索ajax
, ajax的异步请求
, xmlhttprequest
, function
, config
, xhr
, jquery ajax 数据绑定
, Options
, Ajax发送请求
, Ajax请求发送
, ajax请求失败
, ajax发送post请求
, ajax请求数据
jQuery异步请求
jquery、jquery ajax post、ajax、jquery ajax json、jquery ajax教程,以便于您获取更多的相关知识。

时间: 2024-08-04 02:49:07

jQuery ajax:Baidu ajax的相关文章

jQuery ajax(复习)—Baidu ajax request分离版_javascript技巧

你没有看错标题,本文的确是在讲Baidu ajax,不过是很久很久以前的版本了. 由于jQuery ajax模块有800+行,而核心函数jQuery.ajax就有380+行,直接分析这段代码很容易被代码逻辑弄晕. 所以我们先分析一段简单的ajax代码,来自早期的百度七巧板项目. 通过这个来先复习一遍ajax的知识. baidu.ajax.request分离版 复制代码 代码如下: /** * 发送一个ajax请求 * @author: allstar, erik, berg * @name aj

JQuery笔记:Ajax和延迟对象

一.Ajax方法   1.发送请求 Ajax方法 说明 $.ajax([url],options) 使用传入的options发送一次Ajax请求 .load(url,[data],[callback]) 向传入的url生成一次Ajax请求,然后将响应放在匹配的元素中 $.get(url,[data],[callback],[returnType]) 向传入的url发送一个get请求 $.getJSON(url,[data],[callback]) 向传入的url发送一个Ajax请求,将响应作为J

《jQuery、jQuery UI及jQuery Mobile技巧与示例》——9.4 技巧:使用AJAX加载外部页面

9.4 技巧:使用AJAX加载外部页面 至此,示例加载的页面都是已经存在于HTML中的.它们都是把哈希标记和已经存在于DOM树中的id关联在一起. 随着网站的扩大,在一个HTML中加载所有的页面变得不太可能了.使用jQuery Mobile能很容易地创建指向其他页面的链接,这和普通Web应用程序中的做法是一样的.如代码清单9-4所示,链接是一模一样的. 不同之处在于jQuery Mobile处理链接的方式.当链接地址指向的域和当前页面的域相同,默认是使用AJAX请求加载的.可以通过特定的设置关掉

艾伟_转载:使用Ajax和jQuery实现GridView的展开、合并

需求简介:电子商务网站中,查询会员的订单,点击"會員",展现此会员的订单列表.  界面操作:   Step 1 展现会员列表,如下图     Step 2 点击"某一会员"行 展现会员订单列表    实现思路: 1.  使用用户控件(CustomerOrders.ascx)展示订单列表,此用户控件只需要包含Repeater控件并绑定数据源 2.  新建一个简单页面GridViewDrillDownjQueryQAjax.aspx,在此页面引用用户控件,展示用户订单列

Jquery源码分析---Ajax分析

7.1 jquery的ajax常用方法 对于Ajax原理不深入分析.Jquery肯定也 会提供Ajax的实现.对于ajax的请求,可以分成如下的几步: 1.通过 new XMLHttpRequest 或其它的形式(指IE)生成ajax的对象xhr. 2.通 过xhr.open(type, url, async, username, password)的形式建立一个连接. 3.通过setRequestHeader设定xhr的请求头部(request header). 4.通过send(data)请

JQuery处理json与ajax返回JSON实例代码

 json数据是一种经型的实时数据交互的数据存储方法,使用到最多的应该是ajax与json配合使用了,下面我来给大家介绍jquery处理json数据方法 一.JSON的一些基础知识.   JSON中对象通过"{}"来标识,一个"{}"代表一个对象,如{"AreaId":"123"},对象的值是键值对的形式(key:value).    "[]",标识数组,数组内部各个数据之间通过","分

ajax的异步请求-Jquery中$.post和$.ajax的区别在哪里呢

问题描述 Jquery中$.post和$.ajax的区别在哪里呢 一直搞不懂这两种请求到底区别在哪呢,求大神指教,两种我接收数据的时候都是用的eval去解析的. 解决方案 $.post就是post请求,$.ajax可以通过配置type为get/post(及其他可用的http方法,如get,delete)指定提交方法,返回数据jquery一般会通过响应头来判断类型自动生成对应的数据,如响应头为application/json会自动转为json对象,其他当做text/html处理 $.post最终使

求助:使用ajax方式获取新页面内容替换当前整个页面,并执行新页面脚本

问题描述 在当前页面内,使用ajax方式获取一个新网页的内容,替代当前网页,包括:显示新网页所有内容,执行新网页该执行的脚本.用jQuery可以实现,代码如下:$(function(){$.ajax({url:"show.htm",//目标页面dataType:"html",type:"GET",cache:false,success:function(html){$("html").html(html);}});});但是自

反向Ajax:Comet用于服务器与客户端之间响应通信的流和长轮询

客户端的示例使用的是 jQuery http://www.aliyun.com/zixun/aggregation/33906.html">JavaScript 库.在这首篇文章中,我们探索不同的反向 Ajax 技术,使用可下载的例子来学习使用了流 (streaming) 方法和长轮询 (long polling) 方法的 Comet. Web 开发在过去的几年中有了很大的进展,我们已经远超了把静态网页链接在一起的做法,这种做法会引起浏览器的刷新,并且要等待页面的加载.现在需要的是能够通过