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

相关推荐

  • 打印机怎么设置共享?打印机共享工具介绍

    PrinterShare是一款非常使用的打印机共享软件,通过它就可以帮助我们将多个电脑和打印机连接起来,方便对文档进行打印。如果你有多台电脑,但是只有一台连接了打印机。那么就很实用…

    2022年11月25日
  • 如何网恋怎么聊?网恋如何聊天

    网恋最终目的肯定是奔现,但对于很多男生来说,聊天是一个大难题,虽然确定了网恋关系,但却无法通过聊天让关系升级,始终走不到奔现这一步。下面小编就教大家一些网恋聊天技巧。 一、聊天时不…

    2022年10月6日
  • 火炬之光哪个职业厉害?火炬之光2 最强职业

    火炬之光无限的国际服目前已经开测了,不知道有多少小伙伴已经上车体验了呢?在之前的测试中,火炬之光无限就收获到极多的好评,但没有开放氪金项目。 而如今的开放测试,火炬之光的整体样貌也…

    2022年10月11日
  • 长白山一年四季都有雪吗

    长白山一年四季都有雪吗? 一、长白山地处寒冷地带 长白山位于吉林省东北部,地处寒冷地带,是一座以雪山为主的山脉,被誉为“东北雪乡”。长白山自古以来就是一个以雪为特色的地方,因此,雪…

    投稿 2023年4月8日
  • 怎样解酒快速方法?最好的解酒方法

    酒在中国饮食文化中的排名是非常高的,无论你去中国的哪个城市,你都能够见到代表着他们城市的特色酒。甚至去一些民族特色比较强烈的地方,进去时大家为了表示对你的欢迎时会为你送上拦路酒。 …

    2021年11月4日
  • 万科总部大楼(万科总部地址)

    广州万科中心办公总部办公空间由MAG studio设计团队打造。设计以“天际线”为元素,将城市文化、建筑脉络、自然景观都揉进了每个角落。 设计:MAG studio 地址:中国 广…

    2022年11月7日
  • 诺基亚超长待机手机是哪款?诺基亚双卡手机

    此前不久,手机中国了解到诺基亚C31国行版通过工信部入网,型号为TA-1511。诺基亚C31由赫名迪科技有限公司生产,是一款支持双卡双待的4G机型,预计不久后将上市开售。而在今日,…

    2022年10月16日
  • 蝴蝶兰家庭用什么土养?蝴蝶兰的养殖方法和注意事项

    每年的春夏季节,进垃圾桶的花卉里,蝴蝶兰真的不少,一方面是不爱花之人,在春季蝴蝶兰的花期过了之后,觉得养的没意义,就处理掉了。还有一方面,就是蝴蝶兰在养护过程中出现了问题,感觉养不…

    2022年11月30日
  • 中国鬼城有哪些?中国十大鬼城

    近年来,随着房地产行业的火热升温,不少城市都高楼平地起,可是因为不是每个城市都外来人口众多,而本地户有大多有住的房子,所以不少城市房子有了,却没有买的人,时间长了,整个城市也就越来…

    2022年10月11日
  • 紫苏的种植方法

    紫苏,又称香苏、香麻、香菜、藿香等,是一种多年生香料植物,广泛用于中式烹饪、中药材及化妆品等领域。作为一种适应性强、生长快速的植物,紫苏的种植和养护相对容易,深受爱好者的青睐。以下…

    投稿 2024年5月8日