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月14日
  • 手淘首页流量怎么获取(手淘推荐流量怎么获得)

    摘要:手淘首页流量的入口大家是不是都清楚呢?在这篇文章里,来跟大家聊聊淘宝手淘首页流量的入口,让各位更好的了解淘宝的流量应该怎么玩吧。一、首页流量入口。这里我们来简单的描述一下猜你喜欢的展现位置:1、APP首页猜你喜欢位置。这一

    投稿 2022年1月1日
  • 空调出风口温度标准是多少

    空调出风口温度标准是多少? ## 一、空调出风口温度标准 空调出风口温度标准是指空调在正常运行时,出风口的温度应该处于多少的范围内。空调出风口温度标准的正确性对空调的正常运行至关重…

    投稿 2023年7月13日
  • 创业女生开什么店合适一点

    女性创业的热潮正在汹涌,越来越多的女性踏上了创业的道路,但是在众多的创业方式中,女性创业者应该选择开什么店才比较合适呢? ### 一、女性创业的优势 女性创业者具有独特的优势,比如…

    投稿 2023年6月21日
  • 红茶有哪些品种?红茶品种推荐

    红茶作为全发酵茶,以其红茶、红汤、红叶、香甜味醇的特征征服了世界。 而中国的祁门红茶、印度的大吉岭红茶以及斯里兰卡的乌瓦茶更是因其迷人的香气被誉为“世界三大高香红茶”。 &nbsp…

    2022年11月21日
  • 怎么做酸奶?酸奶的发酵方法

    这几天小伙伴们都在后台催我用面包机出自制酸奶的教程,今天就给你们安排上啦,每日一份元气早餐可以唤醒一天的能量,酸奶配上烘焙燕麦片,营养满满,在家自己做简单易上手,根本不会失败! 今…

    2022年12月5日
  • 有好玩的网络游戏吗?没啥可玩的网游

    竞技游戏,射击种类的节奏最快,而且画质和操控也很好。目前除了主流的《CF》、《逆战》、《CSGO》和《守望先锋》等,还有以下五款高画质FPS竞技射击游戏,都是网游玩家必备的作品,会…

    2021年11月13日
  • dreamweaver模板怎么做?dreamweaver导入模板

    使用Dreamweaver制作网页时候,网页的框架往往在某些方面有固定的格式,像是导航栏、banner条,如果每制作一个网页就要重新设计这些内容是很耗时间的,为了提高工作效率,我们…

    2023年1月10日
  • 蚕蛹怎么做好吃简单做法?鲜蚕蛹的做法

    说到蚕蛹,不知道大家有没有吃过,如果是第一次吃蚕蛹,可能你们会觉得心里发毛,很恶心!但如果你吃过,你会发现原来蚕蛹,也算是少见的人间美味!蚕蛹含有丰富的蛋白质和多种氨基酸,营养价值…

    2022年12月9日
  • 迅雷手机版苹果版(迅雷ios版最新下载方法)

    安装方法 把迅雷链接粘贴到iOS浏览器(Safari浏览器)中,点击安装,安装完成后,进入手机设置–通用–设备管理(或是描述文件)–找到手机迅雷…

    2022年10月10日