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

相关推荐

  • oppo和realme什么关系

    Oppo和Realme:一个品牌的双重定位 一、Oppo和Realme的背景 Oppo是一家专注于智能手机研发、制造和销售的公司,成立于2004年,总部位于中国深圳。Oppo的主要…

    投稿 2023年3月31日
  • 如何组装一台完整的台式机?台式机组装

    从上大学开始,我就期望着能有一台自己的桌面 PC。小学时候家里的老电脑用了十年,到高中换了一台笔记本,上大学后为了轻薄我又用了四年的 MacBook Air。被守望先锋吸回 Win…

    2022年10月6日
  • 小发财树怎么养才茂盛?如何养好发财树

    不会养发财树?偷偷告诉你几个小技巧,轻松养出枝繁叶茂的发财树 恭喜发财这四个字,想必大家在过年的时候都想听到。此外,人们在创业开店的时候,也都希望能够获得更多的财富。 第一是因为它…

    2022年12月6日
  • 数据统计分析软件有哪些(常用的市场数据分析)

    数据分析工具这么多,应该用哪个来做分析?这是很多人在做数据分析的时候,经常会碰到一个问题。尤其是新人刚入门的时候,看到下面的数

    2022年1月12日
  • 开发商违约退房流程(开发商违约退房的最有效途径)

    本文知识点: 1、可以申请退房的七种理由 2、退房有哪些流程? 3、退房申请人需要准备的手续有哪些 ? 一、哪种情况可以退房? ①开发商证件不全;②房屋主体结构质量不合格;③实测面…

    投稿 2022年11月26日
  • 公公婆婆不在了(公公婆婆不在了赔偿金孙子能分吗)

    公公突发心梗去世,丧礼结束后,送走亲朋好友,我拖着疲惫的身子回了房。屋子里黑漆漆的,我“啪嗒”一声开了灯,被呆坐在床上的严冰吓了一跳。他脸上挂满了泪痕,眉眼间多了一丝憔悴和哀怨。他突然上前几步抱紧我,将头埋进我发肩呜咽起来,“老婆,我没有爸爸了!我们以后怎么办?呜呜……”我鼻头倏然一酸,轻轻用手抚摸着他的后脑勺,“没事,有我在,我会一直陪着你的。”严冰和我之前交往过的男人不同,他

    2022年1月5日
  • 男高音歌手(著名男高音歌手)

    娱乐圈中,明星的穿衣风格多样又多变,在平时可能为了工作需要,他们还会穿上一些军装来表演,但要说到穿军装,大众认为,还得是真正的军人来穿。 以下男歌手,不同于一般歌手,他们是军旅男歌…

    2022年10月7日
  • 保价费怎么算(ems保价费怎么算)

    随着一年一度“双十一”购物节的结束,又到了“剁手族”收快递收到手软的时候。近年来,随着各大购物节一路攀升的除了成交额,还有退货率。退换货的步骤相信经常“剁手”的市民已经熟练掌握,但是如何保价?保费多少?有没有必要保价?如果快递遗失或者损坏,保价后会赔偿多少?不保价是否会赔偿?这些问题是不少人

    投稿 2021年12月30日
  • 空调开机预警地图在哪里?

    热!热!热!前方预警,一年中最热的日子来了!7月底前,全国多地持续蒸煮模式,高温蔓延全国16省市区,局地逼近40℃。作为人类进化史上伟大的发明之一,空调已成为我们夏天的标配。中国天…

    2022年10月11日
  • 企业微信怎么开通

    企业微信如何开通 一、企业微信的定义 企业微信是一款专为企业定制的沟通和协作平台,它是一款拥有消息、群聊、文件传输、企业应用等功能的综合性应用。它可以帮助企业提高沟通效率,提升协作…

    投稿 2023年8月8日