ajax异步请求和同步请求的区别

Z, ZLW 5177

ajax异步请求和同步请求的区别有:1、代码执行规则不同;2、线程操作数不同;3、效率不同。其中,代码执行规则是指同步需要等待服务器响应再执行下一步,而异步中下一个线程不必等待它执行完就可以开始执行。

1、代码执行规则不同

ajax异步请求:异步执行的时候,数据请求的同时,其他代码语句也可以同步执行,比如,在数据请求的时候,由于某些愿意,需要慢慢的返回请求结果,在这个时候带宽是很空闲的,那么,代码不会等到前面的数据完全请求返回就可以开始后面的代码运行。

ajax同步请求:同步的请求的时候,代码好比在排队,必须是一个挨着一个的去执行,前面的没有结束,没有收到服务器的响应,后面的代码就处于一个阻塞的状态。

2、线程操作数不同

ajax异步请求:多线程操作。

ajax同步请求:单线程操作。

3、效率不同

异步的效率要高于同步。如果数据在线程间共享,那么必须使用同步。

拓展阅读

ajax同步、异步介绍

ajax中根据async的值不同分为同步(async = false)和异步(async = true)两种执行方式;在默认情况下为异步(true)

异步

在异步模式下,当我们使用AJAX发送完请求后,可能还有代码需要执行。这个时候可能由于种种原因导致服务器还没有响应我们的请求,但是因为我们采用了异步执行方式,所有包含AJAX请求代码的函数中的剩余代码将继续执行。如果我们是将请求结果交由另外一个JS函数去处理的,那么,这个时候就好比两条线程同时执行一样。(异步就是不等待服务端响应,接着执行其他的同步代码,等待响应回来之后success,error才会执行)

(现在的大多数项目,都是使用ajax的异步请求。因为这样能过避免服务器的检索给用户带来的时间延迟。异步传输,总是悄悄进行着,用户根本不知道这后面都发生了什么事,用户只要专注着操作浏览器界面就好了,这个对于用户体验来说,非常好。)

同步:

在同步模式下,当我们使用AJAX发送完请求后,后续还有代码需要执行,我们同样将服务器响应交由另一个JS函数去处理,但是这时的代码执行情况是:在服务器没有响应或者处理响应结果的JS函数还没有处理完成return时,包含请求代码的函数的剩余代码是不能够执行的。就好比单线程一样,请求发出后就进入阻塞状态,知道接触阻塞余下的代码才会继续执行。

(发完一个请求时,就一直处于等待状态。比如,你的鼠标一直显示着转啊转哈,直到服务器把数据处理完毕了,再告知浏览器现在可以了,你可以操作其他事情了,可是这对于用户是一个多么痛苦的体验,为了这个请求,页面一直无法操作,就像浏览器“死机”了一样 。所以,同步请求最好慎用。)

一般默认值为true,异步。异步请求可以完全不影响用户的体验效果,无论请求的时间长或者短,用户都在专心的操作页面的其他内容,并不会有等待的感觉。

回复

我来回复
  • 暂无回复内容

注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部