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

相关推荐

  • 推进乡村振兴成果内容(乡村振兴战略成果总结)

    近日,农业农村部办公厅印发《关于开展全国农业科技现代化先行县共建工作的通知》(以下简称《通知》),计划到“十四五”末期,在全国范围内共建6

    投稿 2022年1月7日
  • 淘宝里的地图是实时地图吗?淘宝地图

    淘宝人生发布了地图系统完整剧透,地图系统也要变天了。小淘儿详细罗列变更内容,是惊喜还是失落?小伙伴们一起投票自己想法吧! 从剧透来看,地图系统要进行颠覆性调整。小淘儿整理了完整的变…

    2022年10月17日
  • 2022过年祝福语(2022过年祝福语怎么说)

    1、再见了过去,2022你好呀!2、新的一年,新的开始,新的成就,新的愿望,新的目标。3、我的新年,既要开心,也要热闹欢快。4、新年即是终点,也是起点。5、时间飞逝,我们已经不是幼稚的小孩了,我们已经长大,新的一年里,既要开心也要快乐。6、新年是家人的团聚,团聚就不能没有你!没有你就不够完整,就不是团聚。7、

    2022年1月5日
  • 2022沧州市直(2022沧州市直事业单位招聘公告)

    同步一则重磅消息,从省招投标公共服务平台获悉,沧州市建设投资集团有限公司于12月6日连续发布中心城区城市更新项目7个标段的招标公告。更新标段内容遍布全城、规模阵容浩大,预估总投资达1279亿,城市

    2022年1月4日
  • 苹果icloud照片恢复?icloud没备份照片能恢复

    苹果手机删除的照片怎么恢复?不少iPhone手机用户在给自己手机整理文件过程中,可能会通过整理删除手机照片的方式,毕竟高清像素的照片动辄10M的大小。也因此,不少手机用户错误地删除…

    2021年11月8日
  • 女吊丝什么意思?

    “女屌丝”这一名词来源网络,指的是长相平平,比较喜欢宅在家里,那么这一类的女孩她们性格特点是怎样的呢?   1、很单纯 因为长相平平,一般搭理她们的人不多,所以喜欢宅在家…

    2022年11月14日
  • 迅雷App Store重新上架:迅雷超级会员和白金会员区别(迅雷超级会员和白金会员区别图标)

    时隔四年,近日迅雷终于在AppStore重新上架。(appstore截图)对于当时禁掉迅雷的原因,苹果未曾给出具体的答复。外界多方猜测,迅雷违反了AppStore的条款规定,该条例规定涉及到P2P下载的软件工具不满足AppStore的上架要求。重新上架的iOS版迅雷主要功能有两个:下载以及云盘存储和播放。云盘存储空间为3TB,可以倍速播放和极速云播。会员形式则分为两种:白金会员18元/月

    2021年12月30日
  • 拼多多无货源开网店怎么样啊

    拼多多无货源开网店怎么样?这是很多创业者比较关心的问题,拼多多是一个比较受欢迎的电商平台,但是很多创业者都发现,拼多多要求有货源,所以有很多创业者不知道如何开始,拼多多无货源开网店…

    投稿 2023年6月24日
  • 苹果13pro电池容量

    苹果13pro电池容量:让你的移动生活更加轻松 一、电池容量的重要性 电池容量是指电池可以储存的电量,它是衡量电池性能的重要指标。电池容量越大,可以存储的电量越多,电池续航时间也就…

    投稿 2023年6月27日
  • 汉代皇帝顺序及关系(汉代皇帝皇后顺序列表)

    点击关注,不定期更新历史小知识我们知道每个皇帝都有一个约定俗成的称呼,比如汉朝的皇帝称为汉武帝、汉文帝等,而唐朝的皇帝则称为唐太宗、唐玄宗等,清朝的皇帝称康熙帝、乾隆帝,大家有没有想过为什么会这样称呼,其中的门道又是什么?今天来一一解答谥(shì)号汉武帝、汉文帝是称呼皇帝的谥号,一般是皇帝死后由继任皇帝和

    投稿 2022年1月4日