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

相关推荐

  • 微信小程序如何开发

    微信小程序开发技术正在发展迅速,它的出现大大改变了移动互联网的发展模式,让用户能够在微信中轻松访问各种服务,从而提高了用户体验。那么,如何开发一款微信小程序呢? ## 一、准备工作…

    投稿 2023年7月1日
  • 王者荣耀全部英雄名字?王者cp全部名单

    自15年上线至今,《王者荣耀》中现有系列皮肤共计33组,包括官配与人气组合两大类别,涉及皮肤172款。 此文特对这些系列皮肤的品质、上架/返场时间、售价/获取方式等相关信息做一次详…

    2021年11月11日
  • 女生开什么店适合自己开店做生意

    我是一个热爱生活的女生,毕业后我想开一家店,做自己喜欢的事情,让自己的生活更加有意义。所以,我决定开一家店,做自己喜欢的事情,让自己的生活更加有意义。 一、选择开店类型 在选择开店…

    投稿 2023年7月17日
  • 如何制作微信接龙小程序

    如何制作微信接龙小程序 微信接龙小程序是一种新兴的社交游戏,它可以让玩家们在微信上进行接龙游戏,可以让玩家们在微信上进行接龙游戏,可以让玩家们在微信上进行接龙游戏,可以让玩家们在微…

    投稿 2023年7月8日
  • 唐山大地震发生在哪一年(唐山大地震发生在哪一年哪一月哪一日)

    来源:中央广播电视总台中国之声△地震后的唐山1976年7月28日凌晨3点42分,河北省唐山市发生7.8级强烈地震,仅仅23秒的时间,百年工业城市几乎被夷为平地。三年后正式发布的数据显示,唐山大地震总共造成242769人死亡,约7200个家庭一夜间消失,4200多名孩子

    2022年1月3日
  • qq自动退出怎么回事?为什么qq登上就自动退出了

    曾经的平板市场,苹果的iPad是一家独大的存在,市场上只有iPad和其他。 但随着以华为为首的安卓平板强势崛起,平板市场已经开始了洗牌,在中国的平板市场,华为平板的销量已经与iPa…

    2022年10月20日
  • 环保创业项目有哪些,国家扶持新型环保项目推荐

    **创意与尚早**在当今世界,环保已成为一个紧迫的议题,吸引了越来越多的创业者投身其中。随着社会对可持续发展的需求不断增加,环保创业项目具有巨大的发展潜力。国家对于新型环保项目的扶…

    投稿 2024年5月30日
  • 刨花板十大品牌排行榜

    ## 刨花板十大品牌排行榜:2024年度最佳选购指南 随着家居装修需求的增加,刨花板作为一种常用材料在市场上备受追捧。本文将为您呈现2024年度刨花板十大品牌排行榜,为您提供选购参…

    投稿 2024年5月30日
  • 电脑连接电视方法详解(电脑无线投屏到电视)

    如果电视机是安卓智能电视机投屏,则可以和电脑通过多屏互动软件来建立连接,连接后就可以将电脑屏幕上的画面通过无线传输到电视机上显示出来,实现多屏互动。   具体方法如下: …

    2022年11月18日
  • 过生日送什么礼物?独一无二的生日礼物

    今日来分享关于生日礼物的锦囊妙计,临近TA的生日,也许你已经买好了礼物,但是就差最后一点气氛感和仪式感。这里也许能帮上你的忙。 让对方留下很有纪念性的回忆。那就来看看今天的妙计吧。…

    2022年11月11日