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月13日
  • 红豆薏米茶能天天喝吗?红豆薏米茶长期喝好不好

    红豆薏米汤可以天天喝吗 红豆薏米汤什么时候喝最好 很多人喜欢喝红豆薏米汤,因为有很好的减肥效果。可是红豆薏米汤可以天天喝吗,红豆薏米汤什么时候喝最好?下面小编将为大家详细解答,希望…

    2022年12月6日
  • 苹果14怎么设置防盗?苹果手机防盗

    不少人难免会去到人流量密集的地方如车站等,以防万一可以提前给iPhone做好这几个设置,来防止iPhone丢失。 苹果为 iPhone 11 以及之后推出的更新机型带来了全新功能:…

    2022年11月10日
  • u盘检测不到怎么办(u盘检测不到的解决方法)

      u盘可以转移和存储各种文件,但是如果操作不当的话容易造成u盘的损坏.最近有网友反映自己的u盘在电脑上读不出来,不知道电脑读不了u盘该怎么办.下面小编就

    2022年1月10日
  • 苹果13pro电池容量

    苹果13pro电池容量:让你的移动生活更加轻松 一、电池容量的重要性 电池容量是指电池可以储存的电量,它是衡量电池性能的重要指标。电池容量越大,可以存储的电量越多,电池续航时间也就…

    投稿 2023年6月27日
  • 婴儿睡觉需抱着睡(宝妈分享婴儿为什么喜欢抱着睡的原因以及处理方式)

    最近许多妈妈都在一个相同的问题,那就是自己的孩子睡觉总是特别的浅,特别容易受惊,睡觉的时候必须是妈妈抱着才能安心地睡着,只要妈妈把宝宝放下来,宝宝就会立刻醒过来,这让许多妈妈因为宝…

    2021年11月2日
  • airpods 3如何升级固件?airpods系统怎么升级

    近期,苹果为多款AirPods产品推送了新固件。据了解,AirPods Pro新固件版本为4A402(原版本为4A400),AirPods 3新固件版本为4B66(原版本为4B61…

    2021年11月18日
  • 为什么叫帽子戏法?帽子戏法的来历

    关于帽子戏法的来历目前主要有两种说法: 1. 帽子戏法最早出现在1858年的板球比赛中。 当年,板球手HH·斯蒂芬森连续3次击中门柱得分而被奖励一顶帽子,是第一个获此奖励的板球手。…

    2022年12月4日
  • b站怎么上传手机视频?如何上传视频到b站

    B站作为现在最流行的网络视频平台之一,每天都有大量的博主将自己精心制作的视频上传至B站以获取更多的关注度。但是通常精心剪辑的视频或者时间过长的视频体积都会比较大,而对于B站这样的平…

    2022年11月20日
  • 主板增大内存(苹果手机怎样增大内存)

    XMP:全称是IntelExtremeMemoryProfile(Intel主机板)DOCP:全称是AMDDirectOverClockProfile(AMD主机板)读取内存SPD芯片内的的预置超频频率和时序档案,让内

    2022年1月7日