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

相关推荐

  • 使用微波炉的注意事项(微波炉注意事项)

    需要用到电的东西都需万分谨慎,比如微波炉。微波炉使用时要注意什么?今日就由PChouse为你一一解答。 1、避免使用普通塑料容器:一是加热会使塑料容器变形,二是普通塑料会放出有毒物…

    2022年12月3日
  • 罗勒泡水喝有什么好处?罗勒籽的功效与作用

    一,罗勒的植物学特点 1,名称和分类地位 罗勒是正式中名,这个名称来源于《植物名实图考》,在《中国植物志》中确定为正式中名;学名为Ocimum basilicum Linn.,是在…

    2023年1月14日
  • 雾霾形成原因与治理方法?雾霾应该如何治理

    有这样一则笑话:有一个人在深山中学会了腾云驾雾,他回到城市后,用这个技能做了很多事。但是有一天,他却怎么也飞不起来了。他惊慌地盯着自己,又看看艳阳高照的碧空,半晌,猛一拍脑袋:今天…

    2021年11月12日
  • 无痕模式在哪里开启

    无痕模式:在哪里开启 随着网络的发展,越来越多的人开始使用网络,但是,随着网络的发展,网络安全也变得越来越重要。为了保护用户的隐私,许多浏览器都提供了无痕模式,它可以帮助用户更好地…

    投稿 2023年4月7日
  • 倒库技巧图解(实战倒车入库技巧图解)

    科目二考试倒车入库大家都说教练说的点很清楚,自己也都记住了,可是一到自己上车操作,就不是压线,就是车停歪了。今天小编分享倒车入库一把过的技巧,轻松倒车。 以右倒车入库为例: 1、注…

    2022年10月7日
  • 删除快照有什么用?删除google快照

    当我们网站有错误的页面被Google收录,我们就要像办法让Google收录我们最新的网页和正确的网页,一般有下面几个情况需要我们删除和更新最新的快照信息。 1,网站被黑了,被发表了…

    2022年10月16日
  • 挂面怎么做好吃简单方法?懒人面条简单好吃做法

    挂面因食用方便、价格低、易于贮存,一直是人们喜爱的主要面食之一,面条的做法多种多样,今天教你一道挂面的家常做法,把面条这样做,比方便面好吃百倍,做法和煮方便面一样简单容易,看着有食…

    2022年12月9日
  • 博客怎么弄?创建博客

    您可能想知道成为一个专业的博主是什么样子,但问题是您不知道如何写博客。您只能想到那些好处:设定自己的工作时间,做自己的老板,可以穿着睡衣在家里工作。但”如何做&#822…

    2022年10月20日
  • 0除以任何数都得0对吗?0除以0有意义吗

    为什么规定“0为什么不能做除数”,数学老师都有自己的证明方法。而文科老师们的选择,似乎更侧重于哪个说法“对人生更有意义”。我们看看关于“0为什么不能作除数”的几个常见说法: &nb…

    2022年11月28日
  • 摆摊卖什么赚钱成本又低?适合新手摆地摊做的小本生意

    很多人都听说过这样一句话:“打工是不可能打工的,我这辈子都不可能打工”。这是很多上班族用来调侃自己“搬砖”现状的一种梦想的状态,比如“不上班行不行啊,当条咸鱼行不行啊”,而现实情形…

    2022年10月1日