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

相关推荐

  • 资本公积是什么?资本公积的定义

    一、资本公积是投资者的出资中超出其在注册资本中所占份额的部分,以及直接计入所有者权益的利得和损失,它不直接表明所有者对企业的基本产权关系。 二、资本公积的用途主要是用来转增资本(或…

    投稿 2021年11月8日
  • 玩魔兽世界电脑配置(魔兽世界硬件配置要求)

    5月12号魔兽世界TBC燃烧的远征上线“决战太阳之井”,有网友私信想让推荐一台能玩魔兽世界TBC的电脑配置,业余时间搬砖赚金,弄点小外快。今天小编就给大家推荐一款电脑配置,仅供大家…

    2022年10月21日
  • 22朵红玫瑰花语是什么

    22朵红玫瑰花语:爱的陈述 一、爱的宣言22朵红玫瑰花,是爱的宣言,它们用红色的花瓣,表达着最深沉的爱意。 二、爱的深情22朵红玫瑰花,是爱的深情,它们用绚丽的色彩,传递着最深厚的…

    投稿 2023年7月27日
  • 公司发展阶段怎么写 分享一个企业发展历程范文

    有关公司发展阶段的文章需要涵盖从创立初期到成长壮大的全过程。以下是一篇企业发展历程范文,展示了公司不同阶段的挑战、转折和成功。请阅读以下内容: — **从梦想到现实:一…

    投稿 2024年5月30日
  • 奶奶喜得孙子怎么祝贺

    孙子喜得一子,奶奶喜出望外 一、激动的心情 当孙子喜得一子,奶奶的心情是无比激动的,她把孙子当成自己的孩子,把孙子的孩子当成自己的孙子,一家人团聚在一起,奶奶的心情更是激动无比。 …

    投稿 2023年6月25日
  • 复仇者联盟4人物介绍?复仇者联盟图片

    漫威的超级英雄电影《复仇者联盟4:终局之战》将于4月26日北美上映,观众们也很是期待这部电影。复联3之后的世界到底是什么样子?化灰的英雄们会复活吗?到底谁才能打败灭霸?都是大家好奇…

    2021年11月14日
  • 如何腌制萝卜干(老式腌萝卜)

    今天给大家分享一个腌萝卜干的做法,每年这个季节我家都会腌上一大瓶,酸脆爽口,香辣美味。   现在进入冬季了,上周我们这边已经开始飘起了雪花,记得小时候天冷了妈妈也都会腌好…

    2022年12月2日
  • 如何查自己的上升和下降星座?上升星座查询表格

    什么是上升星座 ? 上升星座就是说人出生的那一刻,东方地平线上正在升起的那个星座。 上升星座是占星学中出生图上“定宫”的主要起始点,上升星座是第一宫,第一宫主要影响是与人格有关。 …

    2022年10月12日
  • 华为mate40e和mate40的区别

    华为mate40e和mate40的区别 一、外观设计 华为mate40e和mate40在外观设计上有很大的不同,mate40e采用了全面屏设计,其屏幕比例为20:9,屏幕分辨率为2…

    投稿 2023年8月16日
  • a10处理器相当于骁龙

    A10处理器相当于骁龙============================================================一、A10处理器简介—&#…

    投稿 2023年7月27日