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

相关推荐

  • 真正免费的pdf编辑器?pdf编辑器免费版

    最近很多朋友都问我,有没有一些免费的PDF工具,自己平时工作中经常要将PDF转各种格式,但是网上下载的PDF工具大部分都是需要会员,那这次我就来给大家分享几个免费无需会员的PDF工…

    2021年11月17日
  • 糯米饭可以做哪些好吃的

    糯米饭是一种古老的中国传统食物,被认为是中国人的精神食粮。糯米饭可以做出很多美味可口的菜肴,口感香甜,营养丰富,是一种健康的食物。下面就来介绍一下糯米饭可以做出哪些好吃的菜肴。 一…

    投稿 2023年8月15日
  • 无线电是什么?无线电基本概念

    说起红色电波,你会想起什么?是电影《永不消逝的电波》,是延安新华广播第一次向世界发出呼号,还是《潜伏》中余则成那个给他带来信息、带来希望、带来信仰的电台? “100年来,无线电通信…

    2022年11月22日
  • 侠盗猎车5秘籍(侠盗飞车5武器全满秘籍)

    不知道当年的你第一次玩到的《侠盗猎车手》是哪个版本呢? 小编玩到的则是《侠盗猎车手:罪恶都市》,毕竟发行的时间刚好是电脑开始流行的年代。而且这款游戏的质量,在当时来说已经是天花板级…

    2022年11月24日
  • 摆地摊有什么技巧吗?摆地摊的技巧

    摆地摊虽然看起来不是很起眼,但中国很多 人都是靠摆地摊赚取第一桶金才发家的。我们经常在大街小巷看到形形色色摆地摊的人们。不要小瞧他们,也许你一个月赚的钱还不如他们一个星期摆地摊赚的…

    投稿 2022年10月20日
  • 怎样恢复微信聊天已删的记录?无备份找回微信聊天记录

    有的用户说,自己新换了手机,但原先的手机保留的聊天记录中,就有很多工作中的重要资料,那该怎么将这些数据恢复到新手机中呢?这个是有方法的!   如果你有备份聊天记录的习惯,…

    2022年12月2日
  • 如何制作网页(网页制作)

    如何创建网页?很多公司企业甚至是个人都想创建自己的网页,但是由于每个人的想法不一样,就需要找到一个合适的创建网页的方法。所以,我们可以怎么创建网页呢?以下有几种方法。 方法一:自己…

    2022年12月4日
  • 手机为啥发热发烫

    手机为什么会发热发烫? 一、手机发热发烫的原因1. 手机组件过热随着手机的普及,越来越多的人开始使用手机,而手机内部的组件也会受到频繁的使用,如处理器、内存、显卡等,当这些组件运行…

    投稿 2023年7月22日
  • 淘宝退款怎么处理?淘宝退款流程

    买家在淘宝平台购物有时会遇到各种各样的问题,在与商家沟通无果的情况下大部分买家会选择向平台进行维权申诉。如果买家在申诉成功之后可以再申请退款吗?我们一起来看一下。 关于商品质量或售…

    2022年10月15日
  • 相约西和,遇“践”未来|我院XIN青年“见微知著”实践团召开暑期社会实践活动行前培训会

    中国青年网天津7月6日电(通讯员徐黎明 刘禹含)为引导青年学生在与现实相结合的“大思政课”中“受教育、长才干、作贡献”,推动社会实践的深入开展,引领青年学生立志做有理想、敢担当、能…

    2024年7月7日