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

相关推荐

  • 女包包品牌大全(名牌大包包经典款)

    有句话说对每一个女生来说都很实用“包治百病”,包包是女生出门的必备单品。女生对于包包的热爱从来不曾减弱,任何一款漂亮好看的包包都会吸引女生的目光。今天聊聊适合年轻女生的包包品牌有哪…

    2022年10月16日
  • 苹果蓝牙耳机怎么改名字?苹果二代蓝牙耳机名字

    在过很多人习惯于使用有线耳机,通过耳机可以有效地隔绝外界噪音,享受音乐世界。现在有了更好的选择,很多无线耳机纷纷面世。其中比较优秀的产品有苹果的AirPods Pro,那么AirP…

    2021年11月7日
  • 百里香叶的功效与作用(百里香叶的用法)

    百里香 百里香唇形科百里香属多年生亚灌木,百里香品种繁多,按照叶型分有宽叶、窄叶、花叶几种类型。常见有柠檬百里香、黑龙江百里香、地椒、铺地百里香等,抗寒零下20℃安全越冬,抗旱,耐…

    2023年1月15日
  • 硬盘分区怎么分(戴尔g3 3590bios设置图解)

      新电脑买来,一般情况下,我们都会对硬盘进行分区操作,这样可以有利于硬盘分区管理,那怎么安全又快速实现硬盘分区呢?

    2022年1月15日
  • 怎样在网上下载视频?下载视频最简单的方法

    平时我们在电脑上看视频,想要保存下来,却发现没有下载按钮,或者需要付费会员才能下载,顿时就没了兴趣。今天就来教大家3个套路,全网视频任你保存。   一、网页元素审查 1.…

    2022年11月25日
  • 没关系用英语怎么说?没关系不用觉得抱歉英语

    01 All right & That’s all right 有一些英语词组或是口语,长得其实有点像,就比如All right和That’s al…

    2022年12月8日
  • 顶级肠粉酱汁配方?肠粉酱汁的做法

    广东肠粉是我最喜欢吃的早餐美食了,但是我不生活在南方沿海,所以很难吃到这个地方特色美食,今天在家自己做,通过认真实验,终于做出了一盘像样又美味的肠粉了。 做好的肠粉 一杯肠粉专用粉…

    2021年11月5日
  • 全球十大保险公司最新排名榜单(全球保险公司排名)

    根据2021年《财富》世界500强排行榜显示,全球共有59家保险公司上榜,其中中国保险公司占了11席。下面根据其排名分别介绍全球十大保险公司的情况如下: 一、联合健康集团(美国) …

    2022年11月10日
  • 磷矿的用途是什么

    磷矿石是含磷的矿石,多产于沉积岩,磷是重要的化工原料,也是农作物生长的必要元素。磷矿石在农业、医药、火柴、染料、制糖、食品、纺织、玻璃、陶瓷、国防工业中均有重要用途。 磷矿石主要用…

    2023年11月4日
  • 虚拟机怎么安装系统(图文讲解)

    本文介绍虚拟机安装win10系统的教程,有不知道怎么下载vm虚拟机的观看我另一篇文章   安装完成之后在主界面点击创建虚拟机   选择自定义(高级),(典型是简…

    2022年12月23日