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.孙子对爷爷说:”老虎在这里,我去把他叫醒.” 孙子对爷爷说,老虎在那里,他去把它叫醒。 2.老师再三叮嘱我们说:”你们假期一定要认真完成作业.” 老师再三叮嘱我们说,假期一定要…

    投稿 2022年10月21日
  • 小米蓝牙耳机怎么重新配对?小米air重新配对

    只要是以蓝牙进行通讯的耳机,都需要打开智能手机中蓝牙功能,此方法适用于各类蓝牙耳机或蓝牙设备。首先,打开智能手机中蓝牙功能,打开需要建立连接的蓝牙设备,在蓝牙设备列表中找到该设备名…

    2021年11月14日
  • 苹果x是双卡吗?苹果x可以双卡双待

    用闲置的iPhone 实现双卡双待? 大家好,相信有些人会有一些旧款的手机如iPhone 5s-iphone6s等手机,那么这些手机淘汰了是不是就没有用了?答案是 不! 假如你手上…

    2021年11月12日
  • 电影长津湖最新票房(长津湖)

    抗美援朝题材战争电影《长津湖》含预售票房已超56.94亿,正式超越2017年上映的《战狼2》摘得中国影史票房榜冠军,同时成为全球影史战争题材票房冠军、全球华语电影票房冠军,并继续位…

    投稿 2022年10月11日
  • 4399生死狙击官网下载?456下载生死狙击

    纵横交错的迷阵,布满了众多极其相似的结构,令人深入其中后无法立即脱身。《4399生死狙击》极限跳跃模式全新地图“迷阵”,分为普通和困难两种难度,开启新的身法挑战!与时间赛跑,超越极…

    2021年11月13日
  • razer笔记本怎么超频( 笔记本cpu超频教程)

    很多人都知道台式电脑内存可以进行超频,但是不确定笔记本是对可以支持,其实笔记本也是可以进行超频的,目前的笔记本仅支持最高DDR3 1600内存,我们可以将一些DDR3 1333内存…

    2022年12月30日
  • 网络设备有哪些?网络设备功能

    几种常见的网络设备 1、 中继器:工作在物理层上的连接设备,适用于完全相同的两类网络的互联,主要功能是 通过对数据信号的重新发送或者转发来扩大网络传输的距离。 最简单的网络就是两台…

    投稿 2022年10月17日
  • 提纲格式怎么写好看?提纲格式

    在小学高年级的语文写作中,老师总会强调,要列好提纲,因为这样不容易跑题,也会明确作文的主题。但是在实际的写作练习中,往往学生们不会列提纲,也不会写作文。更没有养成列提纲写作的习惯,…

    2022年11月26日
  • 提新车15个注意事项有什么?接新车注意事项

    1、检查购车发票、车辆合格证、一致性证书、车辆说明书、机动车登记证书、三包证明等材料是否齐全,否则会影响后续登记; 2、检查里程表,一般20公里以下是正常的,超过的话就需要注意,可…

    2022年12月15日
  • 大学生买什么笔记本电脑好?学生用笔记本电脑推荐2022

    高考成绩已经出炉,相信同学们也开始着手准备大学装备,比如必不可少的笔记本电脑,一台全能高效的笔记本,不仅将成为你大学最得力的助手,也将为你精彩的大学生活留下最浓郁的一笔美好记忆。 …

    2022年11月24日