最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

关于多个Ajax请求执行返回先后的问题示例探讨

来源:动视网 责编:小采 时间:2020-11-27 20:08:14
文档

关于多个Ajax请求执行返回先后的问题示例探讨

关于多个Ajax请求执行返回先后的问题示例探讨:这篇文章主要与大家探讨下关于多个Ajax请求执行返回先后的问题,对ajax感兴趣的朋友可以参考下关于多个Ajax请求执行返回先后的问题示例探讨文章有时候在一个业务事件处理流程上,可能会遇到点击了一个按钮或者其他事件触发了一个动作需要执行两个以上的Aja
推荐度:
导读关于多个Ajax请求执行返回先后的问题示例探讨:这篇文章主要与大家探讨下关于多个Ajax请求执行返回先后的问题,对ajax感兴趣的朋友可以参考下关于多个Ajax请求执行返回先后的问题示例探讨文章有时候在一个业务事件处理流程上,可能会遇到点击了一个按钮或者其他事件触发了一个动作需要执行两个以上的Aja


这篇文章主要与大家探讨下关于多个Ajax请求执行返回先后的问题,对ajax感兴趣的朋友可以参考下关于多个Ajax请求执行返回先后的问题示例探讨文章

有时候在一个业务事件处理流程上,可能会遇到点击了一个按钮或者其他事件触发了一个动作

需要执行两个以上的Ajax请求,但是可能要顾虑到Ajax请求执行的先后顺序,有时候Ajax请求顺序出问题,会导致各种问题

例如现在有两个ajax事件,分别为ajax1 ,ajax2

一个叫做main的方法调用执行入口

1.

如果我们按照上面的方法去执行,表面上看似乎是让ajax1先执行,ajax2后执行。如果不仔细想,有些人会认为ajax1先执行完,之后才会执行ajax2.事实上真的会如此吗?

答案是 不一定 。当然对于有多个ajax请求对执行返回顺序没要求的情况,我们不需要过多考虑谁先执行,谁先返回的
那要是考虑ajax事件执行先后顺序以及返回顺序呢

要是这样那怎么解决ajax事件的执行返回先后顺序呢

当然现在你应该会想到ajax回调函数,Good,这是一个好主意
现在按这种思路改变一下方法,方法如下

这样看起来,你是不是觉得Very Good呢?真的吗?真的是Very Good吗?

Maybe,But in some case ,这样写可能有些不方便,当然也许你可能不会遇到,但是我遇到了一种比较特殊的情况
比如下面这种可能

你认为这种情况可以满足ajax2在ajax1先执行并且先执行完毕吗

仔细想想你会发现得到答案

No!
Now ,How to solve this proplem . How to make sure ajax2 finished before ajax1 .

当然,你可能会说,这不简单,把ajax1的调用放进ajax2方法回调方法ajax2Callback的最后面

不得不承认这是一种解决方案,但是如果是一个很古老的项目,已经做了好几年的项目了。里面调用复杂,要尽量去避免修改以前的底层方法,也许你为了修改这个bug,就这样简单解决了,你可能又会创造多个bug.

那到底还有没有好的方法去解决了?

Sure,solve it easy .但是工作经验不足的人很少会一下想到,只会用前面的办法草草解决问题,不管三七二十一。

而我采用了一种比较笨的方法,而且还存在一定问题,使用了setTimeOut定时器执行一次,但是问题想必大家都知道,谁知道这个Ajax会执行多久了,还好有大神指导了下我,
还记得对数组排序吗,说道这个,也许你会好奇,这与数组排序有啥关系。下面会告诉你答案

代码说明一切:

看出来没,是不是很有趣,没有修改最低层的方法,仅仅修改了main方法,是不是很像数组排序里的当我们比较两个值大小时,不管你用冒泡排序,还是快速排序,是不是都设置了一个临时变量去存储值。当然排序比较大小时,你可以没必要设置临时变量,仅仅用一个^运算符去做赋值比大小,甚至你可以偷懒到直接调用系统的Arrays.sort()方法,当然这都可以

function changeSearchContactType(obj)
{
if (!obj)
{
return;
}

var contactType = obj.value;

var origRenderTemplate = renderTemplate;
renderTemplate = function(data)
{
origRenderTemplate(data);
ajaxAnywhere.submitAJAX('setSearchContactType');
}
var result = TemplateHelper.changeSearchContactTemplate(contactType, contactUIUID);
renderTemplate = origRenderTemplate;
return result;
}

文档

关于多个Ajax请求执行返回先后的问题示例探讨

关于多个Ajax请求执行返回先后的问题示例探讨:这篇文章主要与大家探讨下关于多个Ajax请求执行返回先后的问题,对ajax感兴趣的朋友可以参考下关于多个Ajax请求执行返回先后的问题示例探讨文章有时候在一个业务事件处理流程上,可能会遇到点击了一个按钮或者其他事件触发了一个动作需要执行两个以上的Aja
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top