关于AJAX

Ajax是Asynchronous JavaScript and XML的缩写。主要用于页面无刷新请求数据

Ajax简单来说就是通过XMLHttpRequest对象向服务器发送异步请求,从服务器取得数据,然后用js操作DOM来更新页面。

Ajax的工作原理相当于在用户和服务器之间加了—个中间层(AJAX引擎),使用户操作与服务器响应异步化。并不是所有的用户请求都提交给服务器,像—些数据验证和数据处理等都交给Ajax引擎自己来做, 只有确定需要从服务器读取新数据时再由Ajax引擎代为向服务器提交请求。

下面来详细介绍一下XMLHttpRequest.,首先是创建一个XMLHttpRequest对象。

function CreateXmlHttp() {

    //非IE浏览器创建XmlHttpRequest对象

    if (window.XmlHttpRequest) {

         xmlhttp = new XmlHttpRequest();

    }

    //IE浏览器创建XmlHttpRequest对象

    if (window.ActiveXObject) {

        try {

            xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

        }

        catch (e) {

            try {

                xmlhttp = new ActiveXObject("msxml2.XMLHTTP");

            }

            catch (ex) { }

        }

    }

}

XMLHttpRequest对象的方法

1.abort():停止当前请求。

2.open("method","URL",[asyncFlag],["userName"],["password"]):发送请求,建立与服务器之间的连接。method参数可以是GET、POST或PUT。url参数可以是相对URL或绝对URL。这个方法还包括3个可选的参数,是否异步,用户名,密码。

3.send(content):向服务器发送请求。

4.setRequestHeader("header", "value"):把指定首部设置为所提供的值。在设置任何首部之前必须先调用open()。设置header并和请求一起发送 ('post'方法一定要 )。

XMLHttpRequest对象的属性

1.onreadystatechange:每次状态改变所触发事件的事件处理程序。

2.readyState:请求的状态,有5个状态值:

    0 (未初始化)对象已建立,但是尚未初始化(尚未调用open方法)

    1 (初始化)对象已建立,尚未调用send方法

    2 (发送数据) send方法已调用,但是当前的状态及http头未知

    3 (数据传送中)已接收部分数据,因为响应及http头不全,这时通过responseBody和responseText获取部分数据会出现错误,

    4 (完成)数据接收完毕,此时可以通过通过responseXml和responseText获取完整的回应数据

3.responseText:服务器的响应,返回数据的文本。

4.responseXML:服务器的响应,返回数据的兼容DOM的XML文档对象 ,这个对象可以解析为一个DOM对象。

5.status:服务器的HTTP状态码(如:404 = "文件末找到" 、200 ="成功" ,等等)。

6.statusText:服务器返回的状态文本信息 ,HTTP状态码的相应文本(OK或Not Found(未找到)等等)。

一个完整的ajax请求:

function fetchMsg() {

    var data = document.getElementById("username").value;

    CreateXmlHttp();

    if (!xmlhttp) {

        alert("创建xmlhttp对象异常!");

        return false;

    }

    xmlhttp.open("POST", url, false);

    xmlhttp.onreadystatechange = function () {

        if (xmlhttp.readyState == 4) {

            document.getElementById("user1").innerHTML = "数据正在加载...";

            if (xmlhttp.status == 200) {

                document.write(xmlhttp.responseText);

            }

        }

    }

    xmlhttp.send();

}

Ajax的优点

1.页面无刷新请求数据,用户体验很好;

2.异步与服务器通信,不需打断用户操作,响应能力迅速;

3.ajax的原则是“按需加载”,可以减少冗余请求和服务器的负担。

Ajax的缺点

1.破坏了浏览器的后退机制;

2.对搜索引擎的支持较弱;

3.安全问题。

暂时介绍到这里,如果不对,欢迎指出~

你可能感兴趣的:(关于AJAX)