浅谈js的ajax的异步和同步请求的问题
投稿:jingxian
下面小编就为大家带来一篇浅谈js的ajax的异步和同步请求的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
先来看以下代码:
var flag=true; var index=0; $.ajax({ url: "https://www.jb51.net/", success: function(data){ flag=false; } }); while(flag){ index++; } alert(index);
请问最后alert的index的结果是多少?
可能有人会说0呗。实际上却没那么简单。大家可以自己试试看。可以看到最终程序进入了一个死循环!怎么会这样呢!
我们在看一段代码:
var flag=true; $.ajax({ url: "https://www.jb51.net/", success: function(data){ flag=false; } }); alert(flag);
大家看最后alert出flag的值是多少呢?没错,是true!为什么呢?明明我们在ajax请求成功了将flag设为false,怎么还是true呢?这实际上是Ajax的异步机制造成的。
这里解释一下,同步和异步。js是单线程的,由于执行ajax请求会消耗一定的时间,甚至出现了网络故障而迟迟得不到返回结果;这时,如果同步执行的话,就必须等到ajax返回结果以后才能执行接下来的代码,如果ajax请求需要1分钟,程序就得等1分钟。如果是异步执行的话,就是告诉ajax代码“老兄,既然你迟迟不返回结果,我先不等你了,我还有一大堆代码要执行,等你执行完了给我说一下”。
Ajax默认是异步请求的,所以就出现了上面我们看到的结果。也就是ajax里面的代码还没有执行完,先执行了下面的代码。
那么如何使Ajax执行同步请求呢?这就需要设置async。
代码如下:
var flag=true; var index=0; $.ajax({ url: "https://www.jb51.net/", async:false, success: function(data){ flag=false; } }); while(flag){ index++; } alert(index);
async默认是true,也就是异步,我们设置为false,即为同步。这时我们再看看结果吧。
以上就是小编为大家带来的浅谈js的ajax的异步和同步请求的问题全部内容了,希望大家多多支持脚本之家~
您可能感兴趣的文章:
- jQuery ajax全局函数处理session过期后的ajax跳转问题
- ajax实现session不过期(避免页面过期的现象)
- ajax session过期问题的几个解决方案
- 浅析ajax请求json数据并用js解析(示例分析)
- 跨域请求之jQuery的ajax jsonp的使用解惑
- 原生 JS Ajax,GET和POST 请求实例代码
- js每隔5分钟执行一次ajax请求的实现方法
- JS实现定时任务每隔N秒请求后台setInterval定时和ajax请求问题
- 详解JavaScript for循环中发送AJAX请求问题
- 分享JavaScript监听全部Ajax请求事件的方法
- JS Ajax请求会话过期处理问题解决方法分析