javascript中异步请求同步化

  在处理大型公司的异步请求时,为了迎合公司的总体框架,在发送异步请求时想要对获取的数据做为返回值使用,可是却没法实现,由于异步代码老是在同步的执行完后才开始javascript

 开始时用了错误的办法,以下 java

var result;
$.ajax({
url:***,
success:function(data){
result=data;
})
while(!result){
 
}
return reasult;

实际上就算你把while写成死循环最后都不会获取到值,那么怎么获取异步的值呢,聪明的人已经发现,当调试alert时是能够获取到结果的,缘由是当执行alert时js的UI机制会产生阻塞,阻碍同步代码的执行,当同步代码被阻断时,异步代码开始执行,那么咱们怎么使用js的这种模拟框式的阻断模式呢,办法是可行的可是处理起来至关麻烦,由于js天生就是单线程的,并且w3c历来没公布过阻断代码执行的接口,接触底层的模拟框代码不多,就算接触了也不必定能看懂,再次百度发现nodejs有这个方法,可是公司没用这个后端框架,没办法只能另寻办法,而后就想到了ajax的async,固然若是是jquery的ajax代码,咱们直接能够用async:false来处理,可是若是是其余异步代码呢?

个人思路是这样的,仍是利用ajax的同步方法node

var result;
$.ajax({
url:***,
success:function(data){
result=data;
})
while(!result){
 $.ajax({url:***,async:false})  //目的是为了产生阻塞
}
return reasult;

利用ajax同步代码的阻塞效果,在返回结果前就不会执行下面的代码,是否是很爽呢

 博主不易 转发记得留下脚印哦jquery