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

相关推荐

  • 充手机要用多少度电

    充手机要用多少度电? 一、充电的原理 充电的原理是将电能转换成化学能,以满足手机的能量需求。当电池完全放电后,将其充电,电池内部的化学反应将电能转换成化学能,以满足手机的能量需求。…

    投稿 2023年4月10日
  • 为什么充电宝给苹果手机充不上电

    充电宝给苹果手机充不上电:原因分析 一、充电宝的输出功率 充电宝的输出功率是充电宝给苹果手机充不上电的最主要原因之一。充电宝的输出功率越大,充电效率越高,可以更快地给苹果手机充电。…

    投稿 2023年8月16日
  • 网上购物哪个网站最可靠?网上购物的步骤

    随着时代的快速发展,网络购物已成为一种时尚,一种更为普遍的消费方式。 数据显示越来越多的人开始网购!网购已然成为人们生活中必不可少的一部分! 足不出户,轻松购物!网购方便你我他! …

    2022年11月10日
  • 诺基亚为什么不出智能手机了?诺基亚倒闭了

    我至今仍然很怀念大学时用诺基亚手机的时候,大一买了部诺基亚5320,一直用到大四毕业,不卡也不顿,摔了无数次也不坏,最重要的是只卖1500多元,整整用了4年。 现在的安卓1500元…

    2022年11月8日
  • 拌面怎么做?自制拌面

    开胃快手拌面 用料 挂面 100克 香葱 少许 蒜末 适量 小米辣 适量 辣椒粉 1勺 食用油 1小勺 生抽 1勺 米醋 1勺 白芝麻 少许 老干妈 1大勺 清水 适量 &nbsp…

    2022年11月28日
  • 加油卡支付开通的云闪付需要钱吗?云闪付充值加油卡

    一、云闪付。目前,在云闪付做加油省钱活动的有中国银行、华夏银行两家银行信用卡,加满200元后有金额不等的优惠,我已经用过,活动属实。 二、加油app。目前,云油加油、团油、全球购骑…

    2021年11月18日
  • 十大游戏平台?游戏平台

    喜欢网游的小伙伴们不少,那么游戏品牌有哪些呢?目前国内外的游戏平台繁多,很多游戏平台都有着不错的用户体验和实用性,接下来就和大家聊聊电脑有哪些好玩的游戏平台吧。 一、steam游戏…

    2021年11月20日
  • 家中蟑螂多有什么好办法消灭它?灭蟑螂最有效的方法

    不管你把家里打扫得多干净,还是会出现讨厌的蟑螂和蚊子?蚊子怕辣、蟑螂怕香,下面小编为您介绍几个超实用的小妙招,安全无毒又能驱赶蟑螂和蚊子,快学起来吧! 对付蟑螂的方法 方法一 在蟑…

    2022年11月10日
  • 怎么制作微信小程序下单

    微信小程序下单是当今智能手机应用的一种流行方式,它可以帮助用户快速、便捷地完成购物订单。本文将详细介绍如何制作微信小程序下单,以便用户能够更好地了解并使用它。 一、准备工作 在制作…

    投稿 2023年5月10日
  • 吊兰属于什么类植物?吊兰的养殖方法和注意事项

    吊兰是一种常见的绿植,适宜生长在温暖湿润的半阴环境中。由于其枝叶会自然下垂,一般要将其放在高处养护。另外,虽然它是观叶植物,但也是会开花的,它的花期在5月份,花茎从叶丛中抽出,一般…

    2022年11月29日