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年11月25日
  • 宇宙是怎样形成的全过程?宇宙形成的原因

    诞生神话 你知不知道宇宙到底是什么?有人说宇宙就是太空部分,但事实上宇宙又大地出乎人们意料。 按照宇宙学角度来看,宇宙在物理定义上是包含了时间、空间及其内涵。当然它还涵盖了各种能量…

    2022年12月8日
  • 红豆沙怎么做简单?自制红豆沙

    家里经常会用到红豆沙,外面买的太甜太腻,而且肯定有添加剂。何不自己在家做?干净又实惠。来来来,简单又快手的红豆沙做起来 用料 红豆 500g 细砂糖 100g 清水 650g 做法…

    2022年12月10日
  • 电影穿过寒冬拥抱你票房(穿过寒冬拥抱你预估票房)

    猫眼专业版实时见证,2022年1月2日17时19分,电影《穿过寒冬拥抱你》票房破5亿!猫眼评分9.5!《穿过寒冬拥抱你》在上映的第一天,即1月1日18点45

    2022年1月9日
  • 氢氧化镁是沉淀吗?氢氧化镁介绍

    氢氧化镁就一种常见的氢氧化物,那么氢氧化镁是沉淀吗?氢氧化镁的化学式如何写了,下面就一起来看看吧。 氢氧化镁可用离子交换法使盐卤(从海水中制备食盐时的副产品)和氢氧化钙反应制得,然…

    2022年12月5日
  • 微信小程序怎么制作自己的程序下载

    如何制作自己的微信小程序?微信小程序是一种基于微信的应用,它可以让用户在微信中轻松访问自己的应用,而无需下载安装。本文将介绍如何制作自己的微信小程序,以便用户可以在微信中轻松访问自…

    投稿 2023年6月25日
  • 开个小店怎么申请营业执照?办理营业执照流程

    在这个突飞猛进的市场经济下,企业发展的越来越多了,企业的发展离不开营业执照,没有它就没有企业。营业执照是工商行政管理机关发给工商企业、个体经营者的准许从事某项生产经营活动的凭证。其…

    2022年12月5日
  • 排骨汤怎么做好吃又简单方便?排骨汤怎样做比较好吃

    家常排骨汤做法,汤鲜味美营养丰富,快快收藏吧!   莲藕玉米排骨汤 食材 排骨450克、莲藕200g,玉米1根、胡萝卜1根、葱姜 做法步骤: 1排骨剁小块,玉米、胡萝卜、…

    2022年12月11日
  • 网页好玩的游戏(10大网页游戏)

    评分最高的十款游戏,2022年的过两天就整给你们! 第一款:《全面战争模拟器》。 这是一款看起来非常搞笑的沙雕战术模拟游戏,游戏包括玩家自己配置的各种各样的兵种模式,以及自由配置己…

    2022年10月10日
  • 国产帆布鞋?国产帆布鞋老牌子

    明明只是双平平无奇帆布鞋,穿上脚搭配啥都不违和。 可以说,一双好看的帆布鞋几乎能搭配男生和女生所有的衣服。 大牌帆布鞋,售价太贵,要好几百块,还有的抵制新疆棉,拿咱们消费者当韭菜,…

    2021年11月20日