jQuery的ajax async同步和异步介绍

来源:互联网 发布:基础地理信息数据下载 编辑:程序博客网 时间:2024/06/16 04:09

使用ajax加载数据返回页面并赋值,然后前端取出该值,这其中涉及到代码的顺序问题,有时后台还未返回数据,但已执行后面代码,

所以就会造成取不到值

[javascript] view plain copy
  1. $.ajax({  
  2.     type: "post",    
  3.     url: "admin/PfmOptionRuleItem.do",  
  4.     success: function(data){  
  5.         $("#ruleItem").val(data.ruleItem);  //①  
  6.     }  
  7. });  
  8. return $("#ruleItem").val();  //②  
如果①还未从后台返回数据 此时执行②就获取不到值


Ajax的第一个字母是asynchronous的开头字母,这意味着所有的操作都是并行的,完成的顺序没有前后关系。

$.ajax()的async参数总是设置成true,这标志着在请求开始后,其他代码依然能够执行。

如果把这个选项设置成false,这意味着所有的请求都不再是异步的了,这也会导致浏览器被锁死。

虽然官方不建议这么干,只是不能用太多,否则会造成用户体验不佳


举个栗子

[javascript] view plain copy
  1. alert("setp 1");  
  2. $.ajax({  
  3.       url: "admin/PfmOptionRuleItem.do",  
  4.       async: false,  
  5.       success: function(data){  
  6.           alert("hello ajax"); //①  
  7.       }  
  8. });  
  9. alert("setp 2"); //②  
当把asyn设为false时,这时ajax的请求时同步的,也就是说,这个时候ajax块发出请求后,

他会等待在①这个地方,不会去向下执行②,直到①执行完毕

此时依次执行顺序为

setp 1

hello ajax

setp 2

如果async为true 则执行顺序为

setp 1

setp 2

hello ajax

原创粉丝点击