码迷,mamicode.com
首页 > Web开发 > 详细

jQuery的ajax async同步和异步介绍

时间:2018-12-23 13:55:21      阅读:211      评论:0      收藏:0      [点我收藏+]

标签:lang   .net   follow   地方   params   param   view   顺序   admin   

项目中有这样一个需求,使用ajax加载数据返回页面并赋值,然后前端取出该值

这其中涉及到代码的顺序问题,有时后台还未返回数据,但已执行后面代码,

所以就会造成取不到值

 

$.ajax({
	type: "post",  
	url: "admin/PfmOptionRuleItem.do",
	success: function(data){
		$("#ruleItem").val(data.ruleItem);  //①
	}
});
return $("#ruleItem").val();  //②
如果①还未从后台返回数据 此时执行②就获取不到值

 

 

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

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

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

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


举个栗子

 

alert("setp 1");
$.ajax({
	  url: "admin/PfmOptionRuleItem.do",
	  async: false,
	  success: function(data){
		  alert("hello ajax"); //①
	  }
});
alert("setp 2"); //②
当把asyn设为false时,这时ajax的请求时同步的,也就是说,这个时候ajax块发出请求后,

 

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

此时依次执行顺序为

setp 1

hello ajax

setp 2

如果async为true 则执行顺序为

setp 1

setp 2

hello ajax

 

作者:itmyhome

 

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://www.cnblogs.com/captainbed

jQuery的ajax async同步和异步介绍

标签:lang   .net   follow   地方   params   param   view   顺序   admin   

原文地址:https://www.cnblogs.com/skiwnchqhh/p/10163914.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!