一.xmlHttpRequest对象的创建

ajax的核心的XMLHttpRequest对象,下面的代码给出了兼容各个浏览器的方法实现

function createXHR(){
    if(typeof XMLHttpRequest !="undefined"){
        return new XMLHttpRequest();
    }else if(typeof ActiveXObject != 'undefined'){
        if(typeof arguments.callee.activeXString !="string"){
            var versions=["MSXML2.XMLHttp.6.0","MSXML2.XMLHttp.3.0","MSXML2.XMLHttp"];
            var i,len;
            ;len=versions.length;i++){
                try{
                    new ActiveXObject(versions[i]);
                    arguments.callee.activeXString=versions[i];
                    break;
                }catch(ex){

                }
            }
        }
        return new ActiveXObject(arguments.callee.activeXString);
    }else{
        throw new Error("no XHR object available...");
    }
}

事实上,如果不理会IE7之前的版本,使用原生的CHR就能够实现。

二,XHR常用方法

1)xhr.open():接受三个参数,请求类型(get,post),请求的url,是否是异步请求(是为true,否为false)

对于xhr来说,传入open()方法的url末尾的查询字符串必须使用encodeURIComponent()经过正确的编码,下面给出了向现有url添加查询字符串的方法

function addUrlParam(url,name,value){
    url+=(url.indexOf(?"?":"&");
    url+=encodeURIComponent(name)+"="+encodeURIComponent(value);
    return url;
}

2)xhr.send():get为null,post为要发送的数据。

3)xhr.setRequestHeader(),设置请求头

4)xhr.onreadystatechage 设置异步请求的回调函数,为了保证浏览器的兼容性,需要在open()之前指定该回调

5)xhr.timeout 设置请求的超时时间

6) xhr.ontimeout 超时回调函数

在请求过程中,xhr对象的readystate属性会发生变化

1)0:尚未初始化,尚未成功调用open()方法

2)1:启动,已经调用open(),尚未调用send()

3) 2: 发送,已经调用send()

4) 3: 接收,已经接收到部分响应

5)4:完成,已经接收到全部响应数据,客户端可以使用

在收到响应后,响应数据会自动填充xhr对象的下列属性:

1)responseText:响应文本

2) responseXML 如果响应类型是"text/xml"或者"application/xml",该属性有值,否则为空

3)status 响应状态码,一般200是成功的标志,304代表从缓存中取得数据

4)statusText 响应状态说明,最好不要使用,在跨浏览器中不太可靠

三、xhr用法示例

function sendGet(url){
    var xhr=createXHR();
    xhr.onreadystatechange=function(){
        ){
            &&xhr.status<||xhr.status==){
                alert(xhr.responseText);
            }else{
                alert("request was fail");
            }
        }
    }
    xhr.open("get",url,true);
    xhr.send(null);
}

post请求与之类似

四、备注

1)以上方法只是XMLHttpRequest1级的相关方法,XMLHttpRequest1又在此基础上拓展了相关API,这里不再赘述

五、跨域问题解决

1.CORS(跨域资源共享),是W3C的一个工作草案,其背后思想是,使用自定义的http头部,让浏览器与服务器进行沟通,从而决定请求或相应应该成功还是失败。这是自己之前在chrom下跨域请求发现Options方法,以及status为0的原因,具体细节不再展开。这种方法需要修改服务器端代码。

2.图像ping, 图像的src属性不存在跨域问题,可以使用图像的onload和onerror事件处理程序来确定是否接受到了响应,不过这种方法具有两个缺点:1)只能发送get请求,2)无法访问服务器的响应文本,只是一种单向的通信

3.jsonp:利用原生的javascript的时候,通过动态script元素,将其src属性指定为一个跨域的url。当然也可以通过jquery的ajax实现。此时服务器端需要修改,将返回的json字符串包围在回调函数中,而回调函数的名称在请求中由queryString指定。

1)利用原生javascript实现jsonp跨域请求

function handleResponse(response){
    console.log("response:"+response);
    alert(response.name);
}
EventUtil.addHandler(document,"DOMContentLoaded",function(){
    var url="http://127.0.0.1:8888/Bobo1/servlet/TestServlet";
    url=addUrlParam(url,"callback","handleResponse");
    console.log("url:"+url);
    var scriptElem=document.createElement("script");
    scriptElem.setAttribute("src",url);
    document.body.appendChild(scriptElem);
});

与之对象的服务器端代码

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        response.setContentType("text/html");
        PrintWriter out = response.getWriter();
        String callback=request.getParameter("callback");
        String result=callback+"({\"name\":\"bobo\"})";
        out.println(result);
    }

2)利用jquery实现jsonP

$(function(){
    $.ajax({
        url:"http://127.0.0.1:8888/Bobo1/servlet/TestServlet?callback=handleResponse",
        type:"get",
        dataType:"jsonp",
        success:function(){
            handleResponse();
        }
    });

});

服务器端同上

4,推送(comet):具体细节可以参照教材,这里不再详细叙述。

javaScript学习之ajax的更多相关文章

  1. JavaScript学习总结 Ajax和Http状态字

    Ajax及其工作原理 AJAX 是一种与服务器交换数据无需刷新网页的技术,最早由Google公司在谷歌地图里使用,并迅速风靡. AJAX是不能跨域的,如需跨域,可以使用document.domain= ...

  2. 高性能javascript学习笔记系列(6) -ajax

    参考 高性能javascript javascript高级程序设计 ajax基础  ajax技术的核心是XMLHttpRequest对象(XHR),通过XHR我们就可以实现无需刷新页面就能从服务器端读 ...

  3. javascript学习笔记一

    今天看的javascript 应用开发实践指南 看了js库 jquery ,明确了要深入学习jquery的想法. 对于javascript原生态的ajax写法(兼容性只需考虑ie6),封装为函数: f ...

  4. 嘿嘿。今天学习了AJAX的几个方法

    原文:嘿嘿.今天学习了AJAX的几个方法 今天学习了AJAX的几个方法,其实我很早在公司实习的时间就认识了它,但是对它一无所知,也并没有去学习它,今天学习它让我感到很兴奋因为重新了解了它,嘿嘿,下面就 ...

  5. Javascript学习6 - 类、对象、继承

    原文:Javascript学习6 - 类.对象.继承 Javasciprt并不像C++一样支持真正的类,也不是用class关键字来定义类.Javascript定义类也是使用function关键字来完成 ...

  6. JavaScript学习--(智能社视频)

    JavaScript学习,这是智能社官网上的JS视频,讲解的挺不错的,就是没有视频的demo,在视频中附上自己编写的一些demo... 下载地址:http://pan.baidu.com/s/1cPz ...

  7. javascript进阶之AJAX

    AJAX 一 AJAX预备知识:json进阶 1.1 什么是JSON? JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.JSON是用字符串来表示Javas ...

  8. JavaScript之使用AJAX(适合初学者)

      网上关于AJAX的教程和分享层出不穷,现实生活中关于AJAX的书籍也是琳琅满目,然而太多的选择容易令人眼花缭乱,不好取舍.事实是,一般的教程或书籍都不会讲Web服务器的搭建,因此,对于初学者(比如 ...

  9. JavaScript学习历程和心得体验

    一.前言 在过去,JavaScript只是被用来做一些简单的网页效果,比如表单验证.浮动广告等,所以那时候JavaScript并没有受到重视.自从AJAX开始流行后,人们发现利用JavaScript可 ...

随机推荐

  1. 被spring和hibernate4逼疯

    spring3.1整合hibernate4,事务都配置上了的,但getCurrentSession()仍然获得不到 以下是各配置 web.xml ? 1 2 3 4 5 6 7 8 9 10 11 1 ...

  2. [ZZ] 景深效果(Depth of Field) , Pass1 将场景渲染到一个RenderTarget,做为清晰版, Pass2: BluredRT , Pass3: WDepth = Depth / Far_Z_Clip

    http://blog.csdn.net/xoyojank/article/details/1883520   什么是景深效果? 景深效果,简称DOF,在人眼跟光学摄像设备上很常见.如下图: 简单地来 ...

  3. {转自MC}NVIDIA DirectX 11演示DEMO详解

    http://tieba.baidu.com/p/1960826986 图形技术无论如何发展,最终都要落到实际的应用中才有效果.在个人电脑上,图形技术最大的用户除了显示UI和操作界面外,就是呈现美轮美 ...

  4. mysql关于字符串字段数据类型

    字符串类型 字符串类型指CHAR.VARCHAR.BINARY.VARBINARY.BLOB.TEXT.ENUM和SET.该节描述了这些类型如何工作以及如何在查询中使用这些类型. 类型 大小 用途 C ...

  5. empty()与remove([expr])的区别.转

    jquery之empty()与remove()区别   要用到移除指定元素的时候,发现empty()与remove([expr])都可以用来实现.可仔细观察效果的话就可以发现.empty()是只移除了 ...

  6. HTML: 字符實體

    在HTML編寫中,有些字符不適合直接在代碼中寫出,比如>,<, (space空格),",',&等等,這時我們按照一定的格式將它們寫出,比如(大於)> 符號,我們用 ...

  7. Turing Test

    Computer Science An Overview _J. Glenn Brookshear _11th Edition In the past the Turing test (propose ...

  8. Python之集合(set)

    一种语言它越便捷,开发效率越高,初学阶段就会越困难.因为语言的设计者帮你造了大量的轮子,你就要掌握如何使用这些轮子.所以,对初学Python来说,记忆的东西很多. 进入正题. 集合就像是抛弃了值(va ...

  9. Qt 动画快速入门(一)

    Qt-4.6动画Animation快速入门三字决 Qt-4.6新增了Animation Framework(动画框架),让我们能够方便的写一些生动的程序.不必像以前的版本一样,所有的控件都枯燥的呆在伟 ...

  10. C# 判断字符串是否为日期格式

    判断字符串内容是否为日期格式,并返回一个日期变量 string str; DateTime dtTime; if (DateTime.TryParse(str, out dtTime)) { //st ...