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

相关推荐

  • 真三国无双4武器拿法攻略(真三国无双4全道具武器)

    各位玩家小伙伴们好呀,我们今天继续来聊真三国无双系列。   我们本期来聊《真三国无双4》,这是一部维稳的作品,为什么这么说呢?因为前一作《真三国无双3》真正找到了自己游戏…

    2022年11月24日
  • groupon模式(groupon模式介绍)

    Groupon前总裁罗伯·所罗门(Rob Solomon)曾经这样说道:“互联网从来没有真正很好地弥合传统商业与网络之间的差距。所以我们创立了Groupon。” Groupon模式…

    投稿 2022年11月25日
  • 吉首机动车年检多少钱?面包车年审

    汽车年检流程及费用标准 一、汽车年检流程 到机动车检测中心外检场地查验机动车——到业务大厅导办台审核资料取号——到窗口审核资料——核发检验合格标志。 二、汽车年检费用标准 年检的项…

    2021年11月15日
  • 冬季棉服内充物为聚酯纤维好吗?聚酯纤维的衣服好

    冬天去选购外套、杯子、被套发现现在很多材质都用的是聚酯纤维,不知道这聚酯纤维100%的好不好呢?   聚酯纤维100%好不好  有好处也有一定的坏处。   聚酯纤维是由有机二元酸和…

    2021年11月4日
  • dnf最近怎么这么卡?dnf太卡了

    研究了一下午,终于搞明白了dnf16g内存情况下,为啥刚开内存占用率就能达到60%,然后dnf时间开的一长,周常,团本一打,内存占用率甚至能飙到80%。“memory compre…

    2022年10月17日
  • 自建房设计app(自建房设计app)

    图片来源@视觉中国文|唆麻在知乎上,“你为什么会退出B站”的提问,浏览量超过1665万次,收获了3602个回答,很大程度上,这代表了外界对于b站的一个看法。b站正越来越主流化。抛开UGC平台避不开的内容运营问题不谈,绝大

    2021年12月31日
  • 微信小程序商店怎么开通

    如何开通微信小程序商店 随着移动互联网的发展,微信小程序商店已经成为一种普遍的商业模式,它可以帮助企业更好地实现营销和服务。如果您想开通微信小程序商店,请按照以下步骤操作: 一、注…

    投稿 2023年6月30日
  • 广州塔高度是多少米

    ## 广州塔高度 广州塔是中国广东省广州市的一座著名建筑,它位于广州市中心的珠江新城,是广州市最高的建筑物,也是中国第二高的塔楼。它的高度是多少米呢? ### 广州塔的历史 广州塔…

    投稿 2023年8月1日
  • 如何p图修改文字?修改图片的文字

    需要掌握的内容: ①文字放大 ②文字变形 ③文字图形 ④完美抠图 具体操作步骤: 首先准备两张照片: 原图———————背景图 ①使用“剪裁”工具。 首先调入一张照片(高清人物图)…

    2021年11月6日
  • autodesk是什么

    Autodesk:世界领先的3D设计软件============================ ## 什么是AutodeskAutodesk是一家世界领先的3D设计软件公司,专注…

    投稿 2023年7月13日