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

相关推荐

  • iqoo9pro是什么处理器

    IQOO 9 Pro是什么处理器? 一、IQOO 9 Pro的处理器 IQOO 9 Pro是一款搭载高通骁龙865处理器的旗舰级智能手机,它拥有强大的性能,可以满足用户对游戏、多媒体和其他应用的需求。骁龙865处理器是一款高性能处理器,具…

    投稿 2023年7月19日
  • 中国奶粉排行榜(国产奶粉口碑最好的排行榜)

    近年来,随着国家质检部门对奶粉的质量监控的升级,国产奶粉迅速崛起,不管是制奶工艺、质量检测、配方成分都得到了很大的发展,在国内奶粉市场上占很大比重。 中国奶粉更适合中国宝宝的体质,今天小编综合品牌、奶…

    2022年11月23日
  • 命运石之门游戏攻略(命运石之门第一季)

    ——“在各世界之间,唯一能解读这‘执念’去向的说明书!!”2009年发售的《命运石之门》由5pb.与Nitro+合作企划的“科学ADV系列”冒险游戏的第二作,著名编剧林直孝所倾力构筑的科学理论世界观与感人至深的剧情,让这部作品在发售后掀起了巨大反响。而5pb.亦再接再厉,于2015年12

    2021年12月30日
  • 企业erp系统是什么?

    ERP是企业资源计划的简称,是企业资源计划。ERP将一个物流、财务、信息流集成化管理的应用系统,ERP系统由采购、销售、库存等模块组合而成。 企业资源包括人力资源、财务资源、供应链资源(材料资源)等,用ERP系统将…

    投稿 2022年11月17日
  • 中国电影票房前十名(中国影史票房排名)

    在全球电影票房排行榜前十中,有四部影片都属于“漫威电影宇宙”,这四部影片分别是《复仇者联盟4》、《复仇者联盟3》、《蜘蛛侠:英雄无归》和《复仇者联盟》。其中的《复仇者联盟4》,还曾做过一段时间的票房冠军。 …

    2022年10月5日
  • 铺地板前注意事项是什么?地暖铺地板注意事项

    现在很多朋友家中装修的时候都会选择地板,地板会比瓷砖柔和一些,没有那么冰冷。所以我们看到现在很多电视剧里面,客厅都会铺设地板的,这样的地板出现的效果也是比较好看的,那么对于地板铺贴技术你有没有了解呢?…

    2022年12月8日
  • 免费的播放器(永久免费观看播放器的软件)

    之前给大家推荐过一款不错的视频播放器,但是只有windows客户端,今天小佳再分享一款支持全平台的视频播放器,支持几十种视频格式播放。   这款播放器叫GOM Player,是一款免费的影片播放器,支持播放视频和音…

    2022年10月3日
  • 飞利浦是哪国的牌子

    ## 飞利浦是荷兰的牌子 飞利浦(Philips)是一家荷兰的跨国公司,主要从事电子产品的研发、生产和销售,是全球最大的消费电子公司之一。飞利浦电子公司成立于1891年,由荷兰人飞利浦·费利克斯·哈特(Philips·Felix·H…

    投稿 2023年6月30日
  • 领带打法步骤最简单(领带的正确系法)

    穿西装的男生似乎自带着一层滤镜,尤其是系上领带的禁欲感与单手解领带的性感形成鲜明反差,忍不住尖叫啊!但相信还有不少男生其实并不怎么会系领带,这绝对是减分项。而今天就和大家聊聊种实用的打领带方法,小姐姐…

    2022年12月9日
  • 教育实习个人总结(五篇范文)

    教育实习工作总结范文(精选5篇)【篇一】 为使本次教育实习能顺利进行,下面提出混合编队教育实习的试行计划,供各混合编队教育实习队灵活掌握使用,并欢迎各方人士提出宝贵意见。   一、教育实习意义和目的 教育实…

    投稿 2022年9月16日