浅谈js的ajax的异步和同步请求的问题
网络编程 2021-07-04 20:00www.168986.cn编程入门
狼蚁网站SEO优化长沙网络推广就为大家带来一篇浅谈js的ajax的异步和同步请求的问题。长沙网络推广觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
先来看以下代码
var flag=true; var index=0; $.ajax({ url: "https://.jb51./", suess: function(data){ flag=false; } }); while(flag){ index++; } alert(index);
请问alert的index的结果是多少?
可能有人会说0呗。实际上却没那么简单。大家可以自己试试看。可以看到最终程序进入了一个死循环!怎么会这样呢!
我们在看一段代码
var flag=true; $.ajax({ url: "https://.jb51./", suess: function(data){ flag=false; } }); alert(flag);
大家看alert出flag的值是多少呢?没错,是true!为什么呢?明明我们在ajax请求成功了将flag设为false,怎么还是true呢?这实际上是Ajax的异步机制造成的。
这里解释一下,同步和异步。js是单线程的,由于执行ajax请求会消耗一定的时间,甚至出现了网络故障而迟迟得不到返回结果;这时,如果同步执行的话,就必须等到ajax返回结果以后才能执行接下来的代码,如果ajax请求需要1分钟,程序就得等1分钟。如果是异步执行的话,就是告诉ajax代码“老兄,既然你迟迟不返回结果,我先不等你了,我还有一大堆代码要执行,等你执行完了给我说一下”。
Ajax默认是异步请求的,所以就出现了上面我们看到的结果。也就是ajax里面的代码还没有执行完,先执行了狼蚁网站SEO优化的代码。
那么如何使Ajax执行同步请求呢?这就需要设置async。
代码如下
var flag=true; var index=0; $.ajax({ url: "https://.jb51./", async:false, suess: function(data){ flag=false; } }); while(flag){ index++; } alert(index);
async默认是true,也就是异步,我们设置为false,即为同步。这时我们再看看结果吧。
以上就是长沙网络推广为大家带来的浅谈js的ajax的异步和同步请求的问题全部内容了,希望大家多多支持狼蚁SEO~
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指