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年4月4日
  • 什么是优化?优化的目的和意义

    什么是优化问题,它的背后的原理是什么? 通过本文,您将了解一些优化问题的基础知识,以及优化是如何在幕后真正发挥作用的。我会通过两个例子来说明如何构建一个简单的优化问题,并且展示优化问题中要素的更改如何…

    2022年11月9日
  • 英国牛津布鲁克斯大学世界排名

    1、剑桥大学(世界第2) 2、牛津大学(世界第4) 3、帝国理工学院(世界第6) 4、伦敦大学学院(世界第8) 5、爱丁堡大学(世界15) 6、曼彻斯特大学(世界28) 7、伦敦大学国王学院(世界37) 8、伦敦政治经济学院…

    投稿 2023年10月29日
  • 微信小店怎么开直播

    开微信小店直播,是一种有效的提升销量的方式,可以帮助商家实现更多的销售,也可以帮助商家节省更多的营销成本。但是,如何开微信小店直播,是很多商家都在考虑的问题。下面,就来详细介绍一下如何开微信小店直播。…

    投稿 2023年6月26日
  • 中国第一盏电灯是何时?中国是哪一年有电灯的

    中国的第一盏电灯出现在清光绪五年四月初八(1879年5月28日),当时在上海公共租界工部局工作的电气工程师英国人毕晓浦(J.D.Bishop)在境内乍浦路一幢仓库里,以10马力(7.46千瓦)蒸汽机为动力,带动自激式直流发电机发…

    2022年11月19日
  • 耐克性价比高的跑鞋(耐克新款跑步鞋)

    Nike Alphafly NEXT% 2的核心构成基本没变,ZoomX泡沫中底,全掌勺型碳板,双Air Zoom气垫以及Atomknit 2.0鞋面,而橡胶外底和鞋跟进行了较大改进。   Alphafly NEXT% 2 中底仍然是由耐克最轻,最具弹性的泡沫Z…

    2022年11月9日
  • php采集安装教程(Python数据采集流程)

      本篇文章给大家带来的内容是关于php中常用的采集函数的总结(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。  这几天关注了一下PHP的采集程序,才发现用PHP采集内容是这么方便,

    2022年1月9日
  • 怎么删除页码?word页码删不掉改不了

    当我们从网上下载一些Word文档时,想要修改这个文件是不太好操作的。就拿页码来说,一些下载的文档里面有着页码,但Word怎么删除页码呢?对此还是让小编来给大家分享一下步骤。 当我们打算删除页码的时候,具体怎样…

    2021年11月10日
  • 保护环境有哪些做法?如何保护环境

    1 不随地吐痰、不乱扔垃圾 2 节约用水,做到绝不空放水龙头,水流可以适当调小 3 节约用电,夜晚只开一盏灯,没人的房间不开灯,不使用的电器拔掉电源,空调少开,一定要开尽量调高温度 4 克制消费欲望。这一点很多…

    投稿 2022年12月5日
  • 想做微商怎么开始

    开始做微商,首先要了解微商的定义,微商是指利用社交媒体平台,如微信、抖音、微博等,以及其他新兴的互联网技术,从事网络销售活动的经营者。 一、微商的定义 微商,也称为社交商业,是一种新兴的网络销售模式,它…

    投稿 2023年7月16日