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

相关推荐

  • 笑傲江湖职业介绍(笑傲江湖门派)

    在今天刚刚开放的新版《新笑傲江湖》手游中,经典的职业华山七宗得到了重做和强化,呈现出“新面貌”。作为游戏公测时的热门门派职业,老版本的华山七宗也有“职业短板”——输出足够高,但血量…

    2022年11月14日
  • 微信储存空间不足怎么清除垃圾?微信储存空间不足

    分享最实在的玩机技巧,洞察最前沿的科技资讯!大家好,这里是手机科技园! 前两天有粉丝留言说,微信越来越占用手机空间了,问我如何正确清理微信储存空间。下面我给大家带来5个方法,看完后…

    2021年11月15日
  • 请问电脑音箱有哪些品牌?电脑音箱品牌

    电脑音箱可以说是我们居家必备的一款电子产品,它在听音乐、看电影、打游戏时都能营造良好的居家氛围感,电脑音箱不仅能为我们带来宽阔的声场,还能保护我们的听力,避免因为长时间戴耳机而磨损…

    2022年11月11日
  • 品牌形象是什么?品牌形象推广

    品牌故事软文撰写,是企业塑造品牌形象的重要手段之一。企业品牌故事软文,可以通过生动有趣的故事,展现企业的品牌形象,吸引消费者的目光。 企业品牌故事软文撰写的意义 1、品牌故事软文可…

    投稿 2022年11月26日
  • 乌龟的养法,喂养方法?如何养乌龟

    乌龟怎么养?养龟不算难,养出好状态却非易事。从龟的选择到日常维护,不仅要有未雨绸缪的规划,还得有科学的方法。总的来说,养乌龟要做好以下5个方面: 乌龟 一、想要把乌龟养好,最重要的…

    2022年11月29日
  • 香猪价格?小香猪销售

    环江香猪,巴拿马香猪两个品牌在绿色有机市场占据着先机,但市场上普遍提供的是温室猪,也就是大批量饲养的猪,有机绿色香猪所占市场份额并不大,市场况且还是有待填补。且目前绿色香珠的管理缺…

    2021年11月16日
  • 准生证在哪里办?现在还要办理准生证

    1.准生证 办理时间:产前办理,建议怀孕3个月后办理 办理地点:一般在夫妻双方户籍所在地或者现在居住地的街道办事处或计生办进行办理。有的地方也可以网上办理。 所需材料: 夫妻双方身…

    2022年12月5日
  • 衣服上有油渍怎么清洗最有效

    衣服上有油渍怎么清洗最有效?油渍是最难清洗的,因为油是不溶于水的,所以油渍很难用水洗掉。

    投稿 2023年3月3日
  • E类机型有哪些?诺基亚e系列手机

    今天我给大家介绍一下诺基亚E系列第一款手:E50   2006年10月24日,诺基亚发布了首款E系列机型:E50 外观设计采用了直板设计,机身正面及背后的下半部分,采用银…

    2022年11月26日
  • 四喜丸子怎么做?家庭版红烧狮子头做法

    红烧狮子头,汉族特色名菜。是中国逢年过节常吃的一道菜,也称四喜丸子,是取其吉祥之意。这是一道淮扬名菜,有肥有瘦的肉红润油亮,配上翠绿青菜掩映,鲜艳的色彩加上扑鼻的香味,看着就很吊人…

    2022年11月28日