ajax请求

发布时间:2020-07-18 09:50:02 作者:Bartely_Linda
来源:网络 阅读:224

一个完整的Ajax过程如下:

  1. 创建XMLHttpRequest对象

  2. 通过上一步创建的XMLHttpRequest对象,打开一个连接

  3. 绑定事件,对获取到的数据进行处理。一般为请求成功后的回调函数

  4. 发送该请求

根据上面的步骤进行简单的描述:

1. 对于不同的浏览器,创建一个能发起Ajax请求对象的方式不一样。 现代浏览器通过内嵌的XMLHttpRequest()对象即可实现,而老的浏览器(IE6/IE6-)则需要通过一个ActiveX对象来创建。

2. 打开一个到远程对象的请求,需要通过XHR的open()方法实现。语法:

open(method, url, async, user, password)

其中:

3. 通过监控readystatechange事件,判断数据是否请求完成,并进行相关处理。其状态值可以通过readyState获取,有如下5种状态:

4. send()方法用于发送请求,若是POST方式,可以将需要传送的数据作为参数发送,形如send(data),但此时需要先设置XMLHttpRequest请求头的Content-Type为application/x-www-form-urlencoded。

一个简单的Ajax示例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
var XMLHttpFactories = [
    function () {return new XMLHttpRequest()},
    function () {return new ActiveXObject("Msxml2.XMLHTTP")},
    function () {return new ActiveXObject("Msxml3.XMLHTTP")},
    function () {return new ActiveXObject("Microsoft.XMLHTTP")}
];
 function createXMLHTTPObject() {
    var xmlhttp = false;
    for (var i=0;i<XMLHttpFactories.length;i++) {
        try {
            xmlhttp = XMLHttpFactories[i]();
        } catch (e) {
            continue;
        }
        break;
    }
    return xmlhttp;
}
 // 步骤1:建立XMLHttpRequest对象
var xhr = createXMLHTTPObject();
// 步骤2:打开一个连接
xhr.open('GET', 'http://localhost/phpinfo.php');
// 步骤3:绑定对返回数据的回调函数
xhr.onreadystatechange = function() {
    console.log(xhr.readyState +':'+ xhr.status);
}
// 步骤4:发送请求
xhr.send();


jQuery中ajax的4种常用请求方式:
1.$.ajax()返回其创建的 XMLHttpRequest 对象。
$.ajax() 只有一个参数:参数 key/value 对象,包含各配置及回调函数信息。详细参数选项见下。
如果你指定了 dataType 选项,请确保服务器返回正确的 MIME 信息,(如 xml 返回 "text/xml")。
实例:
保存数据到服务器,成功时显示信息。
$.ajax({
       type: "post",
       dataType: "html",
       url: '/Resources/GetList.ashx',
       data: dataurl,
       success: function (data) {            if (data != "") {
               $("#pager").pager({ pagenumber: pagenumber, pagecount: data.split("$$")[1], buttonClickCallback: PageClick });
               $("#anhtml").html(data.split("$$")[0]);

           }
       }
   });
2.通过远程 HTTP GET 请求载入信息。
这是一个简单的 GET 请求功能以取代复杂 $.ajax 。请求成功时可调用回调函数。如果需要在出错时执行函数,请使用 $.ajax。
实例:
$.get("test.cgi", { name: "John", time: "2pm" },
 function(data){
   alert("Data Loaded: " + data);
 });
3. 通过远程 HTTP POST 请求载入信息。
这是一个简单的 POST 请求功能以取代复杂 $.ajax 。请求成功时可调用回调函数。如果需要在出错时执行函数,请使用 $.ajax。
实例:
$.post("/Resources/addfriend.ashx", { "fid": fids, "fname": fnames, "tuid": tuids, "tuname": tunames }, function (data) {        if (data == "ok") {
           alert("添加成功!");
       }
   })4.通过 HTTP GET 请求载入 JSON 数据。
实例:
$.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?tags=cat&tagmode=any&format=json&jsoncallback=?",
function(data){
 $.each(data.items, function(i,item){
   $("<img/>").attr("src", item.media.m).appendTo("#p_w_picpaths");    if ( i == 3 ) return false;
 });
});

推荐阅读:
  1. Ajax 跨域请求
  2. AJAX异步请求

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

ajax j aja

上一篇:PHP+Mysql实现数据库增删改查的方法

下一篇:PHP 7.1.0安装Zabbix 3.0.7问题处理

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》