JQAjax+Promise封装方法

一、ajax

ajax 全称为“Asynchronous JavaScript And XML”(异步JavaScript和XML) 是指一种创建交互式网页应用的开发技术、改善用户体验,实现无刷新效果。

优点:
a、不需要插件支持
b、页面无刷新,使用异步方式与服务器通信,具有更加迅速的响应能力,优秀的用户体验
c、提高Web程序的性能
d、可以把以前一些服务器负担的工作转到客户端,利用客户端闲置的能力来处理,减轻服务器的负担,由于ajax的原则是“按需取数据”,所以就可以最大程度的减少冗余请求,提高性能。

缺点:
a、破坏浏览器“前进”、“后退”按钮的正常功能,可以通过简单的插件弥补 。
b、对搜索引擎的支持不足。
c、安全问题:ajax暴露了与服务器交互的细节。

二、Promise

Pomise是es6中的一个异步处理对象,从它可以获取异步操作的消息,特点:

1)对象的状态不受外界影响。Promise对象代表一个异步操作,有三种状态:pending(进行中)、fulfilled(已成功)和rejected(已失败)。

2)一旦状态改变,就不会再变,任何时候都可以得到这个结果。Promise对象的状态改变,只有两种可能:从pending变为fulfilled和从pending变为rejected。

var  param = {
    index_1: 1
};

var ajax = function (methods, url, param) {

    return new Promise(function (resolve, reject) {
        $.ajax({
            type: methods,
            url: url,
            data: param,
            dataType: "json",
            success: function (data) {
                resolve(data);
            },
            error: function (error) {
                reject(error)
            }
        });
    }
    )
};
var con = "";
ajax("GET", 'data.json', param).then(function (res) {  
 // 启动第一个任务
 // 处理第一个异步任务的结果(每次调用then都会返回一个新创建的Promise对象
    // console.dir(res[1].name);

    $.each(res, function (ket, val) {
        con += "<label>姓名:" + val.name + "</label><br/>"
    });
    $("#div1").html(con);

    var param2 = res[0];
    return ajax('GET', 'data2.json', param2);       // 启动第二个任务
}).then(function (data2) {                          //处理第二个异步任务的结果
    // console.log(data2[0].name);
    var name = "<label>姓名:" + data2[0].name + "</label>";

    $("#div2").html(name);
});
可以使用ES6中的Promise对象来封装ajax请求方法,具体步骤如下: 1. 创建一个Promise对象,该对象接受一个函数作为参数,该函数包含两个参数resolve和reject。 2. 在该函数中,使用XMLHttpRequest对象发起ajax请求,并在请求成功或失败时调用resolve和reject方法。 3. 将XMLHttpRequest对象的open、send和onreadystatechange方法封装到一个函数中,该函数返回一个Promise对象。 4. 在调用该函数时,使用then方法来处理请求成功或失败的情况。 下面是一个简单的封装ajax请求方法的示例代码: ```javascript function ajax(url, method, data) { return new Promise(function(resolve, reject) { const xhr = new XMLHttpRequest(); xhr.open(method, url); xhr.setRequestHeader('Content-Type', 'application/json'); xhr.onreadystatechange = function() { if (xhr.readyState === 4) { if (xhr.status === 200) { resolve(JSON.parse(xhr.responseText)); } else { reject(xhr.status); } } }; xhr.send(JSON.stringify(data)); }); } ``` 在调用该方法时,可以使用then方法来处理请求成功或失败的情况: ```javascript ajax('/api/user', 'POST', {name: 'John', age: 30}) .then(function(response) { console.log(response); }) .catch(function(error) { console.log(error); }); ``` 以上代码中,ajax函数返回一个Promise对象,当请求成功时,resolve方法会返回响应数据;当请求失败时,reject方法会返回错误状态码。在调用ajax函数时,使用then方法来处理请求成功的情况,使用catch方法来处理请求失败的情况。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值