基于jQuery的ajax方法封装
来源: 阅读:648 次 日期:2016-07-27 15:12:26
温馨提示: 小编为您整理了“基于jQuery的ajax方法封装”,方便广大网友查阅!

AJAX 是一种用于创建快速动态网页的技术。这篇文章主要介绍了基于jQuery的ajax方法封装的相关资料,需要的朋友可以参考下

ajax (ajax开发)简介

AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。

AJAX = 异步 JavaScript和XML(标准通用标记语言的子集)。

AJAX 是一种用于创建快速动态网页的技术。

通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

在实际的项目里,ajax的应用频率很高,所以尽管jquery或者其他的一些类似的js库做了非常不错的封装,仍然有进一步封装简化的空间和必要

举一个例子,很久很久以前,我的ajax是这么写的:

$.ajax({

url: 'www.baidu.com/getInfo',

type: 'POST',

data: {

name: 'jack',

age: 18

},

dataType: 'json',

success: function(resp){

// callback

},

error: function(err){

// error code

});

乍一看挺好没啥问题,但是其实success回调里的逻辑可能很复杂,甚至可能会出现ajax回调里再放一个ajax的情况,那这种写法就很糟糕了,全都杂糅在一起

可以进行一个简单的封装,这在之前Deferred对象的随笔里已经有提到

function ajax(url, param, type) {

// 利用了jquery延迟对象回调的方式对ajax封装,使用done(),fail(),always()等方法进行链式回调操作

// 如果需要的参数更多,比如有跨域dataType需要设置为'jsonp'等等,可以考虑参数设置为对象

return $.ajax({

url: url,

data: param || {},

type: type || 'GET'

});

}

// 链式回调

ajax('www.baidu.com/getInfo').done(function(resp) {

// 成功回调

}).fail(function(err) {

// 失败回调

});

但是虽然做到这一步了,问题还是会来,比如我司,成功的回调里还有一层逻辑判断,像这样:

// 我司ajax返回的json数据格式

// 当result为false时,msg中往往有错误信息

{

result: true,

data: {

name: 'jack'

},

msg: null

}

ajax('www.baidu.com/getInfo').done(function(resp) {

// 成功回调

if(resp.result){

// 当resp中result为true时的操作

// 往往这个时候要操作处理resp中的data对象信息

}

else{

// 当result为false时的操作,这时往往会根据resp中的另一属性msg来判断具体处理

}

}).fail(function(err) {

// 失败回调

});

问题有二:

第一,我每个ajax中都需要写一个同样的相对固定的逻辑判断(每个公司或者项目组可能会有不同,但是就项目本身而言,或者放大了到公司来说必然是固定的),我觉得很烦。

第二,如果我只想专注处理数据,比如在成功回调里,我直接拿到要处理要渲染的数据,在失败的回调里我直接拿到错误的代码,有没有这样的可能做进一步的封装。

其实这俩问题是一个,总结一句话,就是不想写那么多if,else。有一句话我觉得说得很好,逻辑是守恒的,但如果是可预见的逻辑,是有精简的可能的,我们这种显然属于可预见的逻辑。

二次封装利用了延迟对象的then方法,具体看代码:

function handleAjax(url, param, type) {

return ajax(url, param, type).then(function(resp){

// 成功回调

if(resp.result){

return resp.data; // 直接返回要处理的数据,作为默认参数传入之后done()方法的回调

}

else{

return $.Deferred().reject(resp.msg); // 返回一个失败状态的deferred对象,把错误代码作为默认参数传入之后fail()方法的回调

}

}, function(err){

// 失败回调

console.log(err.status); // 打印状态码

});

}

handleAjax('www.baidu.com/getInfo').done(function(resp){

// 当result为true的回调

}).fail(function(err){

// 当result为false的回调

});

这就把之前很杂揉的代码进一步的的简化,也方便了维护,比如某一天跟你说result不再是布尔值了,直接改成状态码这样的东西了,如果按以前一个ajax写一个判断,简直要疯。

以上所述是小编给大家介绍的基于jQuery的ajax方法封装,希望对大家有所帮助

更多信息请查看网络编程
手机网站地址:基于jQuery的ajax方法封装
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map