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年6月21日
  • 鸡肝怎么做好吃?清炖鸡肝的做法

    做法1:酱鸡肝 准备食材如下:鸡肝500克,酱油2汤匙,醋2汤匙,葱1根,姜1块,蒜5瓣,八角2个,白糖1茶匙,黄酱1汤匙,油适量 具体做法如下:鸡肝750克左右,用清水浸泡2-3…

    2022年12月26日
  • 无线键盘怎么用?aoc无线键盘使用说明

    在现代生活中,由于城市工作、生活节奏得到加快,很多朋友因为节奏繁忙,选择用无线键盘鼠标代替传统的有线键盘鼠标。但是对于那些对电脑不是很精通的朋友来说,第一次安装无线键盘和鼠标可以说…

    2021年11月16日
  • 怎么做微信下单小程序推广

    微信小程序推广是近几年新兴的一种推广方式,它不仅能够帮助企业提升品牌知名度,还能够提高企业的销售额。但是,如何才能有效地推广微信小程序,让它能够获得更多的用户,从而实现企业的目标?…

    投稿 2023年6月25日
  • iphone怎么导入铃声?iphone手机铃声

    苹果手机铃声设置的都是用原始默认的铃声,因为苹果手机不支持直接将音乐设置为铃声,而且大多数人不清楚苹果怎么换铃声。当然安卓系统就没有这个问题啦。但是苹果的默认铃声听久了也挺腻的,鉴…

    2022年11月9日
  • 邮件合并的步骤(如何进行邮件合并)

    在日常办公中,批量制作简历表、工资单、邀请函等各种文档是常态。 这些文档都有共同的特点:内容相同,个别数据不同,一个个制作就很费时间。 那该如何高效批量制作呢? 这时,就要依靠Wo…

    2022年12月7日
  • 手机号多久不用会被注销?手机号码被停用了怎么恢复

    其实,这样的案例屡见不鲜。我们换下来的电话号都去哪了?实际上,大部分“旧手机号”都被重新启用。 有关数据显示,移动、联通、电信总用户数超过13亿人,仅去年一年就新增了9200多万用…

    2021年11月16日
  • 儒家思想的核心内容主要有哪些?儒家思想的主要内容

    从某种意义上来说,儒家学派既是理想主义学派,也是更贴近现实的。孔子就是个知其不可而为之的人,所以儒家学派注定带有孔子的影子,所以,儒家学派也是知其不可而为之的儒家学派。有人说,明明…

    2022年11月21日
  • win10企业版永久激活方法

    正文是激活工具的简单介绍,建议稍微看一下具体使用方法。对这方面比较熟悉的朋友可直接拉到文章底部,查看获取链接方法。 新安装的电脑,总归是需要激活系统,不然很多功能用不了。有时候已经…

    2024年2月16日
  • 关羽被谁杀死的 死在哪?关羽被谁杀死的

    如果不是深仇大恨,在战场上是不会轻易杀掉俘虏的,这点在古代战场上表现得尤为明显。可凡事都有例外,武圣关羽被俘虏后,立即就被杀掉了,这是为何? 有人说,这是孙权和关羽之间的仇恨太大,…

    2022年11月14日