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

相关推荐

  • 美国五大城市

    The Five Major Cities of the United States The United States is a large and diverse countr…

    投稿 2023年7月23日
  • 哪些专业比较好就业(各专业就业前景排行)

    “反正毕业之后都会做别的,选择什么专业也不重要,看能考上哪个就学哪个吧。”很多学生在面对填

    2022年1月3日
  • ps矩形选框工具怎么是圆角

    PS矩形选框工具怎么是圆角的在PS中,矩形选框工具是一种非常常用的工具,它可以帮助我们快速地绘制出矩形,但是有时候我们需要绘制出圆角的矩形,那么PS矩形

    投稿 2023年3月18日
  • 吉水在哪里属于哪个省?江西吉水县简介

    一行走进吉水县同江万亩稻渔产业基地,探寻吉水县稻渔产业助力乡村振兴的样本经验。 地处江西省中部的吉水县,是庐陵文化中心发源地之一,山江湖相得映彰,森林覆盖率达63.3%。背靠良好的…

    2022年12月1日
  • 怎么把pdf文件变小?pdf文件大于2m如何变小

    pdf文件怎么压缩到最小,这个方法请收好! 文件压缩变小是工作经常会遇到的情况,不管是什么样的格式都是可以利用电脑软件压缩变小的,变小后的文件有利于传输和保存哦。今天咱们就来重点讨…

    2021年11月16日
  • 万科总部大楼(万科集团总部大楼)

    万科总部大厦位于深圳湾超级总部基地滨海一线,设计结合功能性和艺术性,打造集创意高端商业、绿色智能办公、文化休闲广场、户外公共露台等为一体的地标性写字楼,在深圳天际线和超级总部基地占…

    2022年10月15日
  • 暗黑3怎么玩?暗黑3玩法详解

    1.升级途中碰到地精塔一定不要开,在社区频道喊人来一起打,你自己肯定打不完。地精塔顾名思义就是会出很多地精的塔,击杀各种各样的地精会掉落材料、装备、宝石、金钱、血岩碎片。地精塔外形…

    2022年11月25日
  • 鹅蛋怎么做好吃?鹅蛋的经典做法

    不知道什么时候端午节必须吃鸡蛋、鹅蛋了。一个月前掐好了日子腌的鹅蛋正好端午节可以吃了。人生与我真的好奇妙,最近经历了好多事情,每一件事都应该是前世的因,可今世的果又是什么呢?某位哥…

    2022年12月1日
  • 调查问卷模板格式?调查问卷的写法

    问卷调查是我们经常接触到的调查方式,个人或企业想要针对某些问题、现状得出一些结论,以及想要预测某种趋势时,问卷调查几乎必不可少。在这之后,我们会从各维度分析通过调查问卷所获得的数据…

    2021年12月29日
  • 橙子上火吗?橙子上火还是橘子上火

    橙子和橘子的区别 提到橘子和橙子,大家都不会陌生,但是很多人分不清楚橙子和橘子的区别, 两者在长相上有区别,在口感上和营养成分上也是不同的,橙子的体型比较大,而且饱满光滑果皮厚,属…

    2022年12月1日