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月28日
  • dnf称号附魔宝珠叫什么?称号附魔

    特效流是普通玩家福音,也是“零门槛”打军团地下城的保障,不太依赖特色礼包道具。但走特效流派,属强必须限制在250以上,才能触发“大天御”装备伤害。正因为特效流“大天御”套,让拍卖行…

    2022年11月25日
  • 环保项目有哪些?环保创业项目推荐

    环保项目包括哪些,环保与我们日常的工作或生活息息相关,有着紧密的关联,因此,我们不能只听说过,却不知到它具体是如何,下面清之源环保小编整理了一些相关内容和大家分享,一起来看看吧! …

    2022年11月16日
  • 个旧市景点

    老城——让人怀念的景点 一、老城的历史 老城是一座历史悠久的古城,它位于中国西南部的一个小城市,有着悠久的历史。它最初是一个古老的城堡,建于公元前三世纪,当时是一个贸易中心,曾经是…

    投稿 2023年7月29日
  • 什么是反馈控制? 反馈控制表现为

    为了实现各种复杂的控制任务,首先要将被控对象和控制装置按照一定的方式连接起来,组成一个有机整体,这就是一个自动控制系统。 在自动控制系统中,被控对象的输出量是要求严格加以控制的物理…

    2022年11月16日
  • 汽车市场营销的概念(汽车市场营销)

    车市寒冬仍在继续,车企苦不堪言,汽车市场正面临重新洗牌。 在经济下行的大背景下,传统汽车营销强曝光的效果和影响已经微乎其微,如今如何能够快速找到正确的目标受众,并以最有效的方式让品…

    投稿 2022年11月9日
  • 怎样选钻戒性价比最高?钻石购买指南最新

    老铁们,人生的第一个钻戒怎么买,该选什么款式?怎么买最划算呢?今天我来告诉你。 以下几点买钻戒之前一定要知道,至少替你省一半的预算。 钻石是定情信物必选的礼物 一、定尺寸 你们去店…

    2022年11月17日
  • 学生营养早餐食谱大全(营养早餐食谱学生)

    导语:早餐的重点是补蛋白,常给孩子吃这5道早餐,身体健康,长个不愁 蛋白质是生命的物质基础,是人体内必需的营养素之一,无论是谁,都不能缺少蛋白质,特别是正在发育期的孩子,蛋白质不足…

    2022年11月12日
  • 南京名牌大学有几所?南京大学排名

    对学生来说,考出更高的分数就能去更好的大学,其实对高校来说也是一样的道理,获得权威性的认可,就能够提高自身知名度,从而把更优秀的学生吸引到自己的学校来。 近几年,高校之间的竞争越发…

    2022年11月14日
  • 公公婆婆怼我自己(怎么怼公公婆婆)

    文|雪落无尘心理学家武志红老师,在心理分析中讲,婆婆把小夫妻的家当自己的家,是“病”,会影响夫妻感情。姚雪对此深有体会,真是有苦难言。还好,如今她已摆脱了这断婚姻——婆婆一再挑战“隐私”,她怒提离婚:遇到此种婆家,女人不必再忍。0

    2022年1月10日