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

相关推荐

  • 戒指戴法的含义(手上的戒指戴法的意义)

    戒指能不能随便戴在某个手指上,不同手指戴戒指有什么含义呢?别着急,跟随我一起来了解一下十个手指戴戒指的不同含义吧:   1、两个大拇指:都是代表着权利、地位、财富的象征 …

    2022年11月20日
  • 意大利城市有哪些?分享全球城市500强的意大利著名城市

    入选《全球城市500强》的意大利著名城市 意大利的城市(市镇)在行政区划上属第三级行政区,归大区(全国分20个一级行政区)和省、广域市(二级行政区)管辖,目前意大利第三级行政区即市…

    2021年11月1日
  • 路由器无线怎么安装?无线路由器安装步骤图片

    随着网络的普及,WLAN网络走进千家万户,同时随着智能手机越来越普及,人们对WiFi网络的需求也越来越大,但很多人却不会安装和设置路由器。下面就说说该如何安装路由器。 工具准备 一…

    2022年12月17日
  • 大话西游2免费版答题卷(大话2科举答题)

    第十七:今天周三,上号发现今天居然有科举,这可是大话西游很古老的任务了,可惜任务奖励阉割得太厉害了,现在基本没人做了(其实我也不推荐做,经验一般费时间费事得题库里找),上号第一项任…

    2022年11月11日
  • 算盘怎么用?零基础学算盘

    目标:会用算盘进行计数与简单的加减法 算盘是一个古老而实用的计算器。让孩子认识一下算盘,并进行计数与计算挺有意思的。 1.计数 算盘分上下两层,上层两珠,每珠代表数字5,落下一珠代…

    2022年11月30日
  • 华为鸿蒙系统是什么

    ## 什么是华为鸿蒙系统 华为鸿蒙系统是华为公司推出的一款操作系统,它是一款基于安全、可信、开放的操作系统,可以支持多种类型的设备,包括智能手机、智能家居、智能安防、智能汽车等。 …

    投稿 2023年8月17日
  • 勇者斗恶龙3全职业说明(fc勇者斗恶龙3)

    自80年代起,号称“第九艺术”的电子游戏为人类文明贡献了不少新兴IP,被誉为霓虹国民级RPG的《勇者斗恶龙(DQ)》系列也是在那个年代诞生的,其魅力一直征服着众多日式游戏的爱好者,…

    2022年11月8日
  • 迪奥什么意思?dior迪奥品牌介绍

    克丽丝汀·迪奥(法语:Christian Dior),简称迪奥(Dior),是源自法国的国际奢侈品品牌,由法国时装设计师克丽丝汀·迪奥于1946年创立,总部位于巴黎。主要经营时装、…

    2022年11月9日
  • 笔记本键盘点不动了怎么办?笔记本键盘失灵的解决方法

    最近突然发现按键盘上的“Win键”失灵了,没有任何反应。这么一来很多和Win键相关的组合快捷键都使用不了了,比如:Win+R,Win+S,Win+I,Win+E,Win+Q。是我键…

    2023年1月7日
  • 老人打了疫苗要注意什么(老人打了新冠疫苗要注意什么)

    随着新冠病毒变异株在全球流行的反复,我国“外防输入、内防反弹”压力不断增大,防控形势严峻而复杂。接种新冠病毒疫苗是全球公认预防个人感染的有效手段之一,特别对降低重症、危重症有很好保护。因此,本着“应接尽接”“应快尽快”原则,全社会都要鼓励和支持老年人积极接种新冠疫苗。老年人接种新冠疫苗注意事项一接

    2022年1月5日