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

相关推荐

  • 手机如何连接电脑(电脑如何连接手机设备)

    今天给大家分享 “手机和电脑怎么无线连接?” 手机和电脑连接相互传输文件,是我们工作和生活中比较常用的,两者之间相互传输文件的方式有很多。在这以前,我们介绍了用微信电脑版和手机之间…

    2022年12月3日
  • android状态栏透明效果(android透明背景代码)

      原来做的效果,如下图(顶部有一条明显的橙色状态栏):  改过之后(顶部状态栏是透明的):&

    2022年1月10日
  • 8开纸尺寸是多少厘米(包装常用尺寸纸张尺寸)

    常用的平张印刷纸张尺寸相信大家在网上已经看到过很多了,全开,对开,4开,8开,16开,32开等等都很常见。 今天和大家分享一下包装印刷的卷筒纸尺寸,以及一些选择纸张尺寸的小窍门。 …

    2021年11月1日
  • 怎么画冰激凌?冰淇淋简单画法可爱

    绘画要点 1.细节多的物品可以先从整体画起,然后再细致刻画细节。 2.注意类似圆柱形物品的体积感。 完整线稿   简单六步,教你画一个超级好吃的糖果冰激凌 绘制线稿 &n…

    2022年11月22日
  • 小米6充不进去电是怎么回事

    小米6充不进去电是怎么回事?小米6充不进去电是一个普遍存在的问题,许多用户反映在尝试充电时,手

    投稿 2023年3月4日
  • 110级召唤师走什么属强?召唤师110版本加点

    副本相关总结 首先是不同于宣传会上的BOSS等级,新副本的BOSS等级一律为140级故100级的CDR装备包括带改造的魔战等装备仍然存活。换装黑雾仍然可以使用,但是在110版本失去…

    2022年11月24日
  • 奥格瑞玛怎么去雷霆崖

    奥格瑞玛是一个古老的城市,位于艾泽拉斯大陆的西北部,它是一个充满活力的城市,也是艾泽拉斯大陆上最古老的城市之一。奥格瑞玛有许多古老的建筑,以及

    投稿 2023年3月6日
  • 海绵宝宝是一种原始的什么动物?海绵宝宝属于什么

    万万没想到的是,动画片中可爱的海绵宝宝竟然是真实存在的一种海洋生物。 Unexpectedly, the lovely SpongeBob in the cartoon turne…

    2022年11月28日
  • u盘坏了无法识别怎么办(u盘损坏怎么修复)

    电脑U盘因为自己的误操作导致出现问题,越弄越坏,最后可能会导致U盘报废,为了解决U盘问题修复的问题,今天分享一下常见的问题和解决方法。1、U盘插到机器上没有任何反应U盘数据修复:无论任何方案的U盘想要工作都必须具备以下几个条件:(1)供电,分为主控所需的供电和FLASH所需的供电,这两个是关键,而U盘电路非常的简单,如没有供电一般都是保险电感损坏或3.3V稳压块损坏,说到稳压块再这里也说一

    2022年1月3日
  • 如何刷睫毛自然款?太阳花睫毛制作教程

    大家好,学姐上线了。本篇文章我们将为大家分享明星们的保养秘籍,好物分享以及穿搭时尚,希望通过这些小技巧的学习能对你有所启发,那么接下来就开启我们的时尚之旅吧! 学姐自己本身也是一个…

    2021年11月3日