什么时候使用异步或同步AJAX
标准web应用程序同步处理web访问者和服务器之间的交互。这意味着一件事接一件事发生;服务器不执行多任务。如果单击按钮,消息将发送到服务器,并返回响应。在接收到响应并更新页面之前,您不能与任何其他页面元素进行交互。
显然,这种延迟会对web访问者的体验产生负面影响——因此使用AJAX。
AJAX是什么?
AJAX不是一种编程语言,而是一种集成了与web服务器通信的客户端脚本(即在用户浏览器中运行的脚本)的技术。此外,它的名称有些误导:虽然AJAX应用程序可能使用XML发送数据,但它也可以只使用纯文本或JSON文本。但通常,它使用浏览器中的XMLHttpRequest对象(从服务器请求数据)和JavaScript显示数据。
AJAX:同步或异步
AJAX实际上可以同步和异步地访问服务器:
同步地,其中脚本停止并等待服务器在继续之前发回回复。
异步,其中脚本允许继续处理页面,并在页面到达时处理回复。
同步处理请求类似于重新加载页面,但只下载所请求的信息,而不是整个页面。因此,同步使用AJAX比完全不使用它要快,但它仍然要求访问者在与页面进行任何进一步交互之前等待下载。通常,用户知道他们有时需要等待页面加载,但不习惯在站点上出现持续的、显著的延迟。
异步处理请求可以避免从服务器进行检索时的延迟,因为访问者可以继续与web页面交互;请求的信息将在后台处理,响应将在页面到达时更新页面。此外,即使响应被延迟(例如,在非常大的数据的情况下),用户可能也不会意识到这一点,因为他们在页面的其他地方占用了时间。然而,对于大多数响应,访问者甚至不知道向服务器发出了请求。
因此,使用AJAX的首选方法是尽可能使用异步调用。这是AJAX中的默认设置。
为什么使用同步AJAX?
如果异步调用提供了这样一种改进的用户体验,为什么AJAX提供了一种进行同步调用的方法呢?
虽然异步调用在大多数情况下都是最好的选择,但是在极少数情况下,允许访问者继续与web页面交互是没有意义的,直到特定的服务器端流程完成。
在许多情况下,最好完全不使用Ajax,而只是重新加载整个页面。AJAX中的同步选项适用于少数无法使用异步调用但无需重新加载整个页面的情况。例如,您可能需要处理一些订单很重要的事务处理。考虑这样一种情况:web页面需要在用户单击某个内容之后返回一个确认页面。这需要同步请求。
以上就是什么时候使用异步或同步AJAX的详细内容,更多请关注其它相关文章!
上一篇: PHP遍历某文件夹下全部文件方法示例
推荐阅读
-
jquery ajax 同步异步的执行示例代码_jquery
-
ajax 同步和异步XMLHTTP代码分析
-
vue中使用async、await和promise实现异步API的同步调用
-
vue 使用 async 和 await 实现异步 axios 同步化(实战案例:数据异步校验通过后,再执行保存)
-
vue 中使用 async/await 将 axios 异步请求同步化处理
-
微信小程序 ———— 异步请求中使用async/await实现同步请求
-
async await 就ajax因果调用解决方案(思路:以同步的思维解决异步的调用)
-
iOS中使用NSURLConnection处理HTTP同步与异步请求
-
iOS中使用NSURLConnection处理HTTP同步与异步请求
-
微信小程序中使用Async-await方法异步请求变为同步请求方法