jquery ajax 请求小技巧实例分析

2020-05-16 18:41:23易采站长站整理

本文实例讲述了jquery ajax 请求小技巧。分享给大家供大家参考,具体如下:

jquery   是一个非常好用的js框架,它为我们提供了很多工具。启动异步请求就是很好用的一个工具

官方推荐的ajax 请求格式


$.ajax({
url:"http://xxxxxxxxxxxxxxxxx/",//你的域名
dataType:"json", //对服务器返回的结果进行该数据格式处理 我这里写了json 也可以红xml、text、html 等格式
type:"get', //请求到服务器的方式 我这里是get 也可以用其它形式 如post
beforeSend:function(res){}, //在请求之前会调用这个方法 其中的res 就是XMLHttpRequest 对象
success:function(result){} //服务器返回的数据进行dataTyoe 设置的格式 处理后返回的结果
})

在这其中,

$.ajax()
  方法中传入的数据是一个json   这不难发现吧。  那我们完全可以这样去调用


var ajaxJson = {
url:"http://xxxxxxxxxxxxxxxxx/",
dataType:"json",
type:"get',
beforeSend:function(res){}, //在请求之前会调用这个方法 其中的res 就是XMLHttpRequest 对象
success:function(result){}
}
$.ajax(ajaxJson); //这样去使用。

如果我们想用户在某一个时刻只进行一个请求,而不会产生多余的请求怎么办呢?

在ajax 前面添加一个判定。


var ajax_oper = {
ajax_status : true, //当前ajax执行状态
ajax_json : function(ajaxJson){
if(!this.ajax_status) return false; // 当这个条件成立的时候,就认为当前有一个正在执行的ajax操作
$.ajax(ajaxJson);
}
}

然后 我们在ajaxJson变量中添加如下配置


var ajaxJson={
url:"http://xxxxxxxxxxxxxxxxx/",
dataType:"json",
type:"get',
beforeSend:function(res){
ajax_oper.ajax_status = false;
},
success:function(result){
ajax_oper.ajax_status = true;
}
}
$.ajax(ajaxJson);

这样就可以在每次请求的时候判定一下 当前是否有正在执行的ajax请求 如果有就返回,不去执行。如果没有就执行。当一个ajax执行完毕后我们将ajax_oper的状态调整回来等待下一次请求的进行更改。

当然在移动web开发当中

touch
事件 有点违背原理,我们在测试的时候发现,在同一时间。
touch
事件被触发了多次,并且产生了多个ajax请求。更改ajax_status并没有起到作用,分析的方案是 touch事件灵敏到了,连ajax_oper的状态还没更改就已经被触发了多次,也就是在统一时间多个ajax请求都在执行