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

相关推荐

  • 口碑最好的奶粉排名(世界奶粉排名)

    德国爱他美白金版 参考国际妈咪APP:246/800g 理由: 不添加蔗糖和麦芽糊精,配方添加双重HMO母乳低聚糖、益生元组合、天然乳脂及高含量的DHA,在宝宝的抵抗力提升、防止便…

    2022年11月25日
  • 什么是会意字?会意字,举例回答

    讲两个有关会意字的故事。 很久以前,有户人家,院中种了一棵桂花树。八月,桂花盛开,芳香馥郁,沁人心脾…… 一天,儿子蹦蹦跳跳放学归来,刚入院中,看见父亲挥动斧头,正准备将桂花树砍倒…

    投稿 2021年11月14日
  • 奥达曼任务?奥达曼副本攻略

    “滚服”降至,不少小伙伴摩拳擦掌跃跃欲试。为了更快地顶到60满级,且契合“滚服”大力提倡做任务的宗旨,【哇哦牛】我小结下适合等级的任务地图,希望能对大家有所帮助。 1-6级:本种族…

    2021年11月30日
  • 狗养什么品种比较好?建议穷人养的10种狗

    想养狗了,又担心自己是新手怕养不好,很讨厌大晚上的狗叫声吵着自己和邻居睡不着觉,下面我为大家介绍几种性格很好比较适合新手饲养的狗狗。 一、金毛犬(大型犬) 金毛犬 金毛是出了名的暖…

    2022年10月1日
  • 女生适合开什么公司?

    女性开公司的机会越来越多,但是不同的行业对女性有不同的要求,那么女性适合开什么公司呢? 一、服务行业 1、美容美发店:美容美发行业是女性最擅长的行业之一,而且现在美容美发行业发展得…

    投稿 2023年6月30日
  • 怎样恢复qq聊天记录?恢复qq聊天记录

    QQ对大家来说都不陌生,但想恢复QQ的聊天记录却很难。当我们频繁使用QQ时,会产生出很多的聊天记录,但也会因为我们的一些操作上的失误导致聊天记录的删除。QQ聊天记录删除了怎么恢复?…

    2022年12月11日
  • Apple id在哪里看?apple id充值

    在苹果和开发商准备应对影响App Store订阅的监管变化之际,这家公司又给了印度客户一个优惠–向他们的Apple ID充值可以获得20%的奖金。在印度,向其Apple…

    2022年10月24日
  • 苹果x多少寸?iphone x的尺寸大小

    关于‬苹果‬各机型‬尺寸‬,我‬在日常‬逛‬苹果‬官网‬发现果在 iPhone11 的官方介绍页面上新推出了屏幕大小对比介绍,可以让不了解尺寸的用户直观的看到各类 iPhone 型…

    2021年11月11日
  • 世界城市排名(世界十大城市)

    全球化发展的如今,各国的GDP总量都在稳步上涨,比如去年,我国的GDP总量突破了114万亿人民币,再次保持了8.1%的高速增长,而各国的经济发展,都是离不开地区直接的协同共进的。 …

    2022年10月2日
  • 我的电脑在哪里找?华为我的电脑在哪里找

    很多朋友使用电脑时,发现电脑桌面的“我的电脑(此电脑或计算机)”消失不见了,本期文章以Windows 10 64位系统为例,教大家如何恢复它。   一、设置 进入电脑桌面…

    2022年12月5日