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

相关推荐

  • 入团仪式流程的细节描写(入团仪式意义何在)

    今年是中国共青团成立100周年。“五四”前后,各地团组织将集中举行入团仪式。今年的入团仪式,要突出“喜迎二十大、永远跟党走、奋进新征程”主题,既要做到规范有序,又要落实疫情防控要求…

    2022年12月9日
  • 完美世界手游羽灵攻击多少?完美世界羽灵技能

    羽灵作为《完美世界:诸神之战》中唯一的奶妈职业一直广受玩家喜爱。羽灵在游戏中承担着为自己伙伴加血和各种增益buff复活队友等重要位置,所以在团战和刷副本的时候,一定少不了羽灵的身影…

    2022年11月8日
  • 小程序怎么弄成链接跟二维码的

    小程序链接和二维码的作用 随着移动互联网的发展,小程序的普及也越来越广泛,小程序的链接和二维码也变得越来越重要。小程序链接和二维码可以帮助用户快速找到小程序,也可以帮助小程序实现快…

    投稿 2023年6月21日
  • 注册新公司的流程(新企业注册流程)

    1注册公司所需资料公司注册需要提供:公司名称、经营范围、注册资本金、股东信息及股份分配、高管信息(法人、监事、财务),注册地址信息,

    投稿 2022年1月2日
  • 门店小程序买单功能怎么开通

    开通门店小程序买单功能,是提升门店经营效率的有效方式,可以大大提高消费者的支付体验,也可以让商家节省大量的人力成本。那么,如何开通门店小程序买单功能呢? ## 一、准备工作 在开通…

    投稿 2023年6月25日
  • 新兴行业有哪些?现在的新兴行业

    近年来,很多人选择来到农村创业,如从事规模化种植或大型养殖业,只不过这类产业风险比较大,市场行情好时赚得盆满钵满,但一旦行情差那就要亏损惨重。 其实,下面6个隐藏乡村的新兴致富产业…

    2022年11月20日
  • 螃蟹不能和什么一起吃?螃蟹食物相克大全完整版

    秋风起,螃蟹肥。盼望着盼望着,吃大闸蟹的日子就快来了!死螃蟹吃了据说会中毒?那生螃蟹呢?老听人说螃蟹不能跟柿子同吃,是真的吗?吃货朋友们,让我们一起摩拳擦掌,提升姿势,做好吃蟹的准…

    2022年11月30日
  • 什么牌子的车性价比高?性价比最高的私家车

    如今的汽车市场可谓是一天一变样,玩智能的,搞颜值的,追求低价买高配的,随意挑出一款车型,就能有五六个“标签”。但看似繁花锦簇的市场,实际上却暗流涌动。 俗话道“样样通,样样松”,没…

    2022年10月20日
  • 黑五是哪一天

    黑五:每年最大的购物狂欢============================ ### 什么是黑五 黑五(Black Friday)是美国每年的第四个星期五,也是美国每年最大的购…

    投稿 2023年7月7日
  • 平价眼霜排行榜?眼霜哪种好用又便宜

    眼部肌肤是最脆弱,最容易出皱纹的地方,眼部皮肤护理不好分分钟就出卖你的年龄。提前保养与及时护理眼部肌肤变得尤为重要!市场眼部护肤品千百样,到底谁家更好呢?小编为大家选出了十款评价相…

    2021年11月14日