当前位置:首页 > 技术文章 > 正文内容

面试官:给我说说什么是同步异步?(同步异步的区别)

今天是刘小爱自学Java的第95天。

感谢你的观看,谢谢你。

话不多说,开始今天的学习:

一、同步、异步请求

浏览器发送请求给服务器,其有同步请求和异步请求两种方式。

1同步请求

什么叫同步请求呢?

就是在发送一个请求之后,需要等待服务器响应返回,才能够发送下一个请求。

之前学的请求是通过浏览器地址栏发送请求,这种方式就是属于同步请求。

但是其有两个缺陷:

①请求必须要等待响应

如果遇到请求阻塞,网络延迟,用户需要等待,这样用户体验效果不好。

②请求时会携带所有的信息

比如说一个form表单,需要填入用户名,密码,手机号,等多个信息。

如果其中有一个信息填写错了,请求失败,又要全部重新填写,会很麻烦繁琐。

我只填写我填错了的不就好了么?

如何解决这个问题?就需要引入异步的概念了。

2异步请求

和同步请求相对,异步不需要等待响应,随时可以发送下一次请求。

如果是同步请求,需要将信息填写完整,再发送请求,服务器响应填写是否正确,再做修改。

但是异步请求是局部页面更新。

比如上述的手机号、密码,邮箱名,在填写时就会发送一个异步请求。

若是格式不正确,会提醒修改,而其它已经填写的正确信息不受影响。

二、原生的Ajax

什么叫Ajax呢?

说白了就是用来发送异步请求的一种方式。

先写一个异步请求案例,再逐步学习。

有一个按钮,给它注册个点击事件,点击就发送异步请求,其具体实现方式共五步:

①创建XMLHttpRequest

XMLHttpRequest是AJAX的基础。

Ajax就是通过XMLHttpRequest这个对象来发送异步请求的。

②onreadystatechange事件

不要看这一大串这么长,翻译过来就是当前数据源的数据将要发生变化时,就可以理解成监听

这个事件就是实现异步请求的核心关键。

为什么异步请求可以不用等待响应?

就是因为这儿设置了一个监听事件。

服务器被监听,一旦readyState为4并且status为200,表明响应成功。

这些属性都是怎么来的,w3c文档中就有说明:

readyState和status都对应有不同的数值,只不过4和200表示响应成功。

③绑定提交地址

open()方法,其有三个参数:

  • method:即请求方式,例子中是GET请求。
  • url:请求路径,"/getAjaxServlet"。
  • async:true表示为异步、false表示为同步,不写默认为true。

④发送请求

send()方法,将请求发送到服务器。

同样的道理,这些方法在w3c文档中也有详细说明。

⑤接收响应数据

也就是在②中判断响应成功时,接受响应的数据,有两种属性:

  • responseText :获取字符串形式的数据。
  • responseXML:获取XML形式的数据。

如果不是XML数据,都使用responseText。

以上就是原生的Ajax,当然实际使用过程中不会这样用,但是面试时可能会被问到。

并且这是基础,学一下也是有必要的。

三、JSON

JSON是一种轻量级的数据交换格式,具有良好的可读性以及便于编写。

在JSON之前一般都是使用xml来传递数据的,将这两种数据格式做一个对比:

相比较而言:json数据更加地简洁。

当然XML也并不是一无是处,其格式统一,就观感而言也有人更喜欢xml这种排版方式。

并且XML出来了很久了,推广深入人心,通用性高,喜欢XML的人还是挺多的。

但是对于传输数据来说,数据是否容易被解析?这是非常重要的。

而json相对于xml而言就具有这样的优势,故在这一块更加地常用。

Json的基础语法

一共有三种数据格式,分别说明:

①对象类型

格式为:{name:value,name:value……}

以键值对的方式存储数据,可以有多个键值对,键值对之间用逗号隔开。

其中name为字符串类型,而value是任意类型。

②数组/集合类型

格式为:[value,value......]

其中value是任意类型。

和数组就很类似,只不过是使用中括号将数据包裹起来的。

③混合类型

即包含对象类型和数组类型。

值得注意的是:

  • JSON数据的key值:字符串类型,必须加双引号。
  • JSON数据的value值:任意类型,如果是字符串则必须加双引号。

时间有限,其中关于json还有一些api就不做专门讲解了,今后使用到了边记边学就好了。

最后

谢谢你的观看。

如果可以的话,麻烦帮忙点个赞,谢谢你。

相关文章

7种超轻量级的Linux发行版,能够帮助你找到适合自己的操作系统

Linux是一种非常受欢迎的开源操作系统,而且有许多版本可以选择。有时候,你需要一种超轻量级的Linux发行版,它可以在资源有限的设备上运行,并且能够快速启动。本文将介绍7种超轻量级的Linux发行版...

2023 年 10 个最佳 Linux 桌面发行版

Linux 操作系统在桌面领域的发展已经不再被忽视,越来越多的用户正在考虑切换到 Linux 上。在 2023 年,我们可以期待更多的 Linux 桌面发行版的推出和发展。这里列举了 10 个最佳的...

Vue3 如何实现父子组件传值?(vue父子组件传值props)

在Vue 3中,要实现父子组件传值效果主要通过props和emit两种机制来实现,下面我们就来详细介绍一下这两种机制。父组件向子组件传值propsprops是Vue组件的一种机制,主要的作用就是实现从...

Vue3开发极简入门(14):组件间通信之props、ref&defineExpose

组件间的关系可以分为:父子关系。以前文的代码为例,最典型的就是App.vue与Car.vue这种,APP是父,Car是子。祖孙关系。如果Car再引入一个子组件,这个子组件与App就是祖孙关系。其他。比...

零基础开始学 Web 前端开发,有什么建议?(附视频教程)

WEB前端看似简单,其实不然,要学的知识点很多很杂,对于零基础学习前端的小伙伴来说,一份详细的前端学习知识点大纲尤为重要。下面,话不多说,直接上干货(全网最全,没有之一)。PS:文末有福利(全阶段视频...

vue3源码分析——实现组件通信provide,inject

引言<<往期回顾>>vue3源码分析——rollup打包monorepovue3源码分析——实现组件的挂载流程vue3源码分析——实现props,emit,事件处理等vue3源...