ajax的原理(java入门基础知识)

一、ajax是什么?

Ajax 全称:asynchronous javascript and XML(异步javascript 和XML)。异步:向服务器发送请求,在等待响应的过程中,浏览器可以做自己的事情,等到成功获取响应后,浏览器才开始处理响应的数据。XML:可扩展标记语言,前后端通信时,传输数据的一种格式。

Ajax是前后端通信时一种异步通信工具。常用在网站注册检索,搜索提示等,可以不重新加载整个页面,只对页面的某部分进行更新的情况。

二、ajax的基本用法

1、创建xhr实例对象。const xhr =new XMLHttpRequest()。XMLHttpRequest,是一个构造函数,ajax实现浏览器与服务器之间异步通信的必要工具。

2、监听事件,处理响应。

xhr.onreadystatechange=()=>{

if (xhr.readyState!=4) return;

if((xhr.status>=200&&xhr.status<300)||xhr.status===304){

console.log(xhr.response)

}

}

Readystatechang:可以监听到readyState的状态变化,readyState的值:0-4。0:未初始化,尚未调用open()。1:启动。已经调用open(),还未调用send()。2:发送。已经调用send,还未收到响应。3:接收。已经收到部分响应。4:完成。已经收到全部响应,可以使用了。status:http状态码。

3。准备发送请求

xhr.open( “http方法”,“地址”,“true(是否异步)”)

4、发送请求

Xhr.send(数据)。携带的数据通过请求体发送,所以post方法可以发送数据,get请求不能发送数据。

三、json数据格式(Xhr.send(数据))

json:javascript object notation,前后端通信中的一种数据格式。json有三种形式,每一种形式都与js数据格式很像,,可以轻松的与js中的数据实现转换,通过json的转换,前后端通信时数据才能更好的识别。

Json储存在以.json为后缀的文件中。json的三种形式:1.简单值形式:数字,字符串,布尔值,null。2.对象形式:{ “name”:“张三”,”age”:18 }。3.数组形式:【1,“aaa”,null, true 】。注意:json中只要涉及到字符串都必须使用双引号,所有形式中,不包括undefined。

Json常用的方法

JSON.parse( ):将json格式的字符串解析成js中对应的值。

JSON.stringify( ):将js中的基本数据类型,对象,数组转化成json格式的字符串。

四、跨域请求(xhr.open( “http方法”,“地址”,“true(是否异步)”))

什么是跨域?https:(协议)www.imooc.com( 域名 ):443(端口号)/course/list(路径)。协议,域名,端口号,任何一个不一样就是不同域。

使用JSONP实现跨域。原理:Script标签跨域不会被浏览器阻止,JSONP主要就是利用script标签,加载跨域文件。

具体过程:

1.服务器端准备好JSONP接口。如:
https://www.imooc.com/api/http/jsonp?callback=handleResponse

2.加载JSONP接口

<script src=“https://www.imooc.com/api/http/jsonp?callback=handleResponse”></script>

3、声明函数

Const handleResponse=data=>{

console.log( data)

}

五、XMLHttpRequest对象(创建xhr实例对象:const xhr =new XMLHttpRequest())

1.XMLHttpRequest属性

⭐️responseText和response:响应的数据。

⭐️timeoout属性:设置请求的最长时间,单位是ms,毫秒。

2、XMLHttpRequest方法

Abort()方法:终止当前请求,一般配合XMLHttpRequest.abort()事件使用。

setRequestHeader( )方法:设置请求头信息。用法:xhr.setRequestHeader( 头部字段名称,头部字段的值 )。例:xhr.setRequestHeader(“Content-Type”,”application/json” ),xhr.send(JSON.stringify({ username:”Alex”,age:18}))。Content-Type:告诉服务器,浏览器发送的数据是什么格式的。

3、XMLHttpRequest事件

Load事件:响应数据可用时触发,可代替xhr.status==4

Error事件:请求发生错误时触发。

abort事件:调用abort()方法时触发。

Timeout事件:请求超时时触发。

原创文章,作者:跳跳,如若转载,请注明出处:https://ziliaobaba.com/1920.html

(0)
跳跳跳跳
上一篇 2021年11月2日 15:26
下一篇 2021年11月2日 15:35

相关推荐

  • 漏电断路器型号规格表?断路器型号规格表

    断路器是一种安全保障的电器产品,在发生电路负载的时候,这种断路器可以自动地切断电路,从而达到保护和保障的目的,避免后期埋下的进一步的安全隐患问题,那么断路器的参数,具体应该如何选择…

    2021年11月15日
  • 变压器规格型号

    变压器规格型号 一、变压器的定义 变压器是一种电气设备,它可以将一个电压转换成另一个电压,而不改变电流大小。它可以将低压电源转换成高压电源,也可以将高压电源转换成低压电源。 二、变…

    投稿 2023年8月11日
  • 2021新手开什么店投资小

    2021新手开什么店投资小? 2021年,新手想要开店投资小,可以考虑以下几种经营方式:网店、礼品店、便利店、餐饮店等。每种经营方式都有其优势和劣势,新手需要根据自身的情况和实际情…

    投稿 2023年7月4日
  • (常用的网络推广方法)企业网络推广方法

    互联网时代,企业发展的过程中网络推广是必不可少的一个环节。企业在网络上进行推广的好坏直接影响到企业的发展。那么随着网络推广的方式越来越多,很多企业不清楚自己到底该如何去做网络推广,…

    2022年11月10日
  • 最近腌制腊肉要腌多长时间?风干腊肉的腌制方法

    近想要自己腌制腊肉吃,听说腌制腊肉之前要进行腌制,那腊肉一般腌几个小时才可以晒干?腌腊肉腌好后要洗了再晒吗? 腊肉一般腌几个小时才可以晒根据实际情况而定。 腌制腊肉需要多长时间,与…

    2021年11月18日
  • 死灵刷图加点(死灵刷图加点最新)

    大家好,暗黑2重制版上线以来吸引了不少的新玩家入坑,但是这款20多年前的老游戏技能和装备属性什么的还是比较复杂的,很多新手玩家也是走了很多弯路,今天给大家带来一个召唤流死灵法师的新…

    2022年11月14日
  • 秦朝一共有几位皇帝?秦朝历代皇帝

    秦国原为周朝时的诸侯国,立国500余年,共经历了33位帝王。 秦人祖先原为西方古老部落。 周孝王时,秦非子为周人养马于汧水、渭水之间,被周天子赐姓为嬴; 周宣王时,秦庄公率兵七千大…

    2022年11月10日
  • ps动作怎么用?PS展示动作

    PS里还有一项操作,能够记录你对画像的所有调整进行记录下来,然后存储下来应用到其他图像上,今天我们就要讲动作的使用。 PS记录动作就是借鉴以前的录音机的功能,PS录的是对图像处理的…

    投稿 2022年12月3日
  • 鲱鱼罐头为什么这么臭?鲱鱼罐头的最佳吃法

    鲱鱼靠屁传播信息 鲱鱼又被叫做鲭鱼,这是一种体型较小的鱼类,它们喜欢成群出动。在我国的青岛、大连也有广泛分布,在大西洋地中海沿岸,鲱鱼是世界上重要的经济鱼类之一。 欧洲的荷兰甚至对…

    2022年12月4日
  • 怎么用电脑发短信到手机?如何用电脑收到手机短信

    由于手机的普及和人脉关系的扩大,很多时候我们需要用到短信群发功能。但是在手机上使用短信群发功能操作上的不便大大降低了工作效率,所以我们迫切需要在电脑上来操作进行短信群发。我们分别通…

    2022年12月17日