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

相关推荐

  • 电脑剪辑视频软件?常用的视频剪辑软件

    为了写好这篇文章,我测评了17款剪辑软件。 最近经常看到有朋友说想做短视频、但又不会剪辑,希望小媒安利一下?哎,那我这不就来了吗?这一个星期内,小媒测评了17款手机剪辑软件,最终给…

    2021年11月17日
  • 爱奇艺可以登录几个设备

    爱奇艺可以登录多个设备==================== ## 什么是爱奇艺 爱奇艺是一家中国大陆的在线视频网站,拥有大量的电影、电视剧、综艺、动漫、体育等节目,满足用户观看…

    投稿 2023年8月2日
  • 怎样可以去眼袋?自己动手制作去眼袋

    怎样去除眼袋?给我三分钟真的可以让你跟眼袋泪沟说再见哟!   如果你想了很多办法,依然没有解决它,那今天呢?我来告诉你一个可以从根源上去解决眼袋和泪沟的问题,并且不反弹,…

    2022年11月30日
  • mes系统都有哪些平台

    MES系统是一种可以支持企业实现生产管理的软件系统,它可以支持企业实现生产计划、生产控制、质量管理、库存管理、设备管理等功能。目前,MES系统已经在各种行业中得到广泛应用,它可以帮…

    投稿 2023年4月3日
  • 绝味鸭脖是哪里的特产?绝味鸭脖发源地是哪里

    绝味鸭脖是比较常见的一种熟食店,它主要是卖鸭肉制品,那绝味鸭脖是哪里的品牌?绝味鸭脖都有什么食品?绝味鸭脖味道麻、辣、鲜、香,非常的好吃,并且绝味的美食尤以辣感而著名。它是武汉的品…

    2022年12月6日
  • p2p平台排名?P2P平台消费

    2019年5月消费金融业务总成交量为354.38亿元,环比上月下降4.37%,占P2P网贷行业2019年5月总成交量的38.1%。本月消费金融业务成交量继续呈现下降趋势,一是因为部…

    2021年11月6日
  • 包粽子步骤(包粽子制作过程)

    2种包粽子最简单方法,步骤讲解很详细,一卷一盖就会,赶紧收藏 端午节到了,不知道你家里有没有开始包粽子,这不昨天上街去买菜的时候,就买了100张的粽子叶。打算今天给家里包上一锅粽子…

    2022年11月30日
  • 玫瑰之战中的手机型号

    玫瑰之战中的手机型号======================== 玫瑰之战是一款由腾讯游戏发行的网络游戏,游戏以现代科技为背景,玩家可以体验到现代科技带来的精彩游戏内容。游戏中…

    投稿 2023年7月4日
  • 深海鱼油胶囊吃了有什么好处?每天吃鱼油胶囊的好处

    长期服用鱼油,控制斑块长大,从而达到预防心梗、脑梗的目的,真的可行吗?上周出门诊的时候,我就遇见一个长期服用鱼油保健品的患者,他在6年前,也就是2015年去他们当地医院做的颈动脉彩…

    2022年11月16日
  • 品胜电池怎么样?品胜电池质量

    品胜PD20W快充套餐的一个小评测,中午刚刚拿到快递,测试机型是苹果Xr128G黑色版,用了两年,电池健康是89,之前一直用原装充电器,偶尔用车载5V2A的充电头,充电时电量剩余1…

    2022年10月6日