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年12月12日
  • 制作网页的软件dw(制作的具体方法)

    在建设网页时,为了快速、高效地完成任务,通常会使用一些具有代码高亮显示、语法提示等便捷功能的网站开发工具。常见的网站建设

    2022年1月11日
  • 电脑缓存文件在哪

    ## 什么是电脑缓存文件 电脑缓存文件是指电脑系统中用来存储临时数据的文件,它们是由操作系统和浏览器自动生成的,用于提高电脑系统的性能。缓存文件可以帮助电脑系统快速访问常用的文件和…

    投稿 2023年7月23日
  • 苦瓜怎么做好吃?苦瓜如何炒好吃

    准备给大家分享一下苦瓜的几种特色吃法,喜欢吃苦瓜的朋友们就赶紧围观吧,喜欢美食的朋友们也别忘了给我点个关注,我每天都会更新分享不一样的美食教程,相信总有一道会是你想学的菜肴哒! &…

    2022年11月27日
  • 创维电视质量怎么样?创维电视 质量

    看看你家电视机上榜了吗,中国有能占几个? NO.1 索尼 所属国家:日本   SONY索尼是横跨电子3C、游戏、金融、娱乐领域的世界巨擘,拥有世界屈指的品牌影响力。索尼是…

    2022年11月20日
  • 休闲男装品牌有哪些?比较高档的休闲男装品牌

    一、轻熟简约风 1.SeaRoad海上公路 推荐指数:⭐⭐⭐⭐⭐ 价格区间:100-400 俗话说的好,“打底选的好,脱衣才没烦恼”, 他们家的羊毛衫、假两件、打底衫性价比都没话说…

    2022年11月25日
  • 固态硬盘怎么用?硬盘正确使用方法

    固态硬盘具备读写速度快、体积小、耗能低等优势,但是在使用固态硬盘过程中,如果不小心将数据丢失了怎么办?如何找回丢失的数据文件?这时固态硬盘数据恢复工具派上了用场。固态硬盘数据恢复工…

    2022年12月6日
  • 鲸鱼是鱼吗?鲸鱼的简介

    生活在海洋里生物都是鱼类吗?鲸鱼是不是鱼?鲸为什么不在水下呼吸?鲸睡觉的时候淹死吗?死后会怎样?我们带着这些疑问,一起来了解一下鲸鱼吧? 鲸鱼是不是鱼? 首先告诉一下大家,鲸虽然是…

    2022年12月3日
  • 水晶头接线顺序?网线水晶头的接线方法图

    在后台收到了小伙伴的私信,说家里买了新房,准备开始装修,但是对接网线、接模块具体应该怎么接不清楚,是不是要用一样的线序、分别应该用什么工具接?今天小泽就来分享一下水晶头、模块、配线…

    2021年11月7日
  • 近几年大学生就业率?大学专业就业率排名

    2022年大学本科专业、高职专业,各自就业率、薪资排名前10的专业!   近几年,越来越多的家长明白了,大学专业的好坏,不但决定着孩子的就业、薪资,更决定着孩子的前程和未…

    2022年11月22日