Ajax解释:异步javascript和XML。

Ajax的使用:

1.创建 XMLHttpRequest 对象

2.向服务器发送请求

            //ajax获取内容
      function getContent() {
            var httpXml;
            try
            {
                if (window.XMLHttpRequest) {
                    httpXml = new XMLHttpRequest();
                }
                else {
                    httpXml = new ActiveXObject("Microsoft.XMLHTTP");
                }
            }
            catch(e) {
                alert("你的浏览器不支持ajax!");
            }
            httpXml.open("GET", "Ajax/ajax.ashx?t=" + Math.random(), true);
            httpXml.onreadystatechange = function () {
                if (httpXml.readyState == 4 && httpXml.status == 200) {
                    document.getElementById("ajax").innerHTML = httpXml.responseText;
                }
            };
            httpXml.send(null);
        }

_ueditor_page_break_tag_

open(method,url,async);

method:请求的类型;GET 或 POST

url:文件在服务器上的位置

async:true(异步)或 false(同步)

send(string)

string:仅用于 POST 请求

在onreadystatechange事件里添加alert(httpXml.readyState); 依次显示1,2,3,4.

responseText与responseXML的区别:

从字面上也可以看出,一个是文本内容,一个是结构化的XML。

 

真正要研究的还是jquery框架中ajax的使用

大多数情况,我使用的也是jquery下的ajax,方便,功能强大。

 

函数 描述 
.ajax() 执行异步 HTTP (Ajax) 请求 
.ajaxComplete() 当 Ajax 请求完成时注册要调用的处理程序。这是一个 Ajax 事件 
.ajaxError() 当 Ajax 请求完成且出现错误时注册要调用的处理程序。这是一个 Ajax 事件 
.ajaxSend() 在 Ajax 请求发送之前显示一条消息 
.ajaxSetup() 设置将来的 Ajax 请求的默认值 
.ajaxStart() 当首个 Ajax 请求完成开始时注册要调用的处理程序。这是一个 Ajax 事件 
.ajaxStop() 当所有 Ajax 请求完成时注册要调用的处理程序。这是一个 Ajax 事件 
.ajaxSuccess() 当 Ajax 请求成功完成时显示一条消息 
.get() 使用 HTTP GET 请求从服务器加载数据 
.getJSON() 使用 HTTP GET 请求从服务器加载 JSON 编码数据 
.getScript() 使用 HTTP GET 请求从服务器加载JavaScript 文件,然后执行该文件 
.load() 从服务器加载数据,然后把返回到 HTML 放入匹配元素 
.param() 创建数组或对象的序列化表示,适合在 URL 查询字符串或 Ajax 请求中使用 
.post() 使用 HTTP POST 请求从服务器加载数据 
.serialize() 将表单内容序列化为字符串 
.serializeArray() 序列化表单元素,返回 JSON 数据结构数据 

一般使用较多的.ajax() .load() .get() .post()

推荐一篇详细讲解的文章:

http://www.cnblogs.com/qleelulu/archive/2008/04/21/1163021.html

$("#ajax").load("Ajax/ajax.ashx", function () { alert("获取成功!"); });

.load()的用法和.get()有很大的相似之处

本博客在留言版块使用了ajax,获取留言内容的代码如下:

           //获取留言信息
      function getGuestMsg() {
            var urltemp = "Ajax/MsgBoard.ashx?a=" + Math.random();
            $.ajax({
                type: "get",
                url: urltemp,
                datatype: "html",
                success: function (context) {
                    document.getElementById("GuestMsgList").innerHTML = context;
                    SyntaxHighlighter.highlight();
                },
                error: function () {
                    alert("ajax请求发生错误");
                }
            });
        }

.ajax()的参数说明(转):

 

参数名类型 描述 
url String(默认: 当前页地址) 发送请求的地址。 
type String (默认: "GET") 请求方式 ("POST" 或 "GET"), 默认为 "GET"。注意:其它 HTTP 请求方法,如 PUT 和 DELETE 也可以使用,但仅部分浏览器支持。 
timeout Number 设置请求超时时间(毫秒)。此设置将覆盖全局设置。 
async Boolean (默认: true) 默认设置下,所有请求均为异步请求。如果需要发送同步请求,请将此选项设置为 false。注意,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。 
beforeSend Function 发送请求前可修改 XMLHttpRequest 对象的函数,如添加自定义 HTTP 头。XMLHttpRequest 对象是唯一的参数。
                     
function (XMLHttpRequest) {

         this; // the options for this ajax request

         }
 
cache Boolean (默认: true) jQuery 1.2 新功能,设置为 false 将不会从浏览器缓存中加载请求信息。 
complete Function 请求完成后回调函数 (请求成功或失败时均调用)。参数: XMLHttpRequest 对象,成功信息字符串。
                     
function (XMLHttpRequest, textStatus) {

         this; // the options for this ajax request

         }
 
contentType String (默认: "application/x-www-form-urlencoded") 发送信息至服务器时内容编码类型。默认值适合大多数应用场合。 
data Object,
String
 
发送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData 选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2'。 
dataType String 

预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息返回 responseXML 或 responseText,并作为回调函数参数传递,可用值:     

"xml": 返回 XML 文档,可用 jQuery 处理。     

"html": 返回纯文本 HTML 信息;包含 script 元素。     

"script": 返回纯文本 JavaScript 代码。不会自动缓存结果。     

"json": 返回 JSON 数据 。     

"jsonp":JSONP格式。使用JSONP形式调用函数时,如 "myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。     

error Function (默认: 自动判断 (xml 或 html)) 请求失败时将调用此方法。这个方法有三个参数:XMLHttpRequest 对象,错误信息,(可能)捕获的错误对象。
global Boolean (默认: true) 是否触发全局 AJAX 事件。设置为 false 将不会触发全局 AJAX 事件,如 ajaxStart 或 ajaxStop 。可用于控制不同的Ajax事件 
ifModified Boolean (默认: false) 仅在服务器数据改变时获取新数据。使用 HTTP 包 Last-Modified 头信息判断。 
processData Boolean (默认: true) 默认情况下,发送的数据将被转换为对象(技术上讲并非字符串) 以配合默认内容类型 "application/x-www-form-urlencoded"。如果要发送 DOM 树信息或其它不希望转换的信息,请设置为 false。 
success Function 请求成功后回调函数。这个方法有两个参数:服务器返回数据,返回状态

 

最后修改:2013 年 07 月 10 日
如果觉得我的文章对你有用,请随意赞赏