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年3月2日
  • 女生新手适合开什么车10万左右

    女生新手适合开什么车10万左右 随着社会的发展,越来越多的女性也开始拥有自己的私家车,但是,当女性新手面临选择10万左右的车时,又会有哪些选择呢?本文将为大家介绍10万左右的女性新手适合开的车。 一、宝马X1 …

    投稿 2023年7月4日
  • 苹果最新旗舰机是哪款(苹果机性价比最高的手机型号)

    降价虽然说是每款手机在售卖过程中基本都要经历的,但从8388元上市价,跌至2K以内,这大跳水的“魄力”绝对是行业仅有的。专注捡漏的小伙伴们,看到这

    2022年1月3日
  • 怎样截长图(怎样截长图华为荣耀)

    分享最实在的玩机技巧,洞察最前沿的科技资讯!大家好,这里是手机科技园!相信大家都用过手机截图

    2022年1月2日
  • 第一次坐飞机所有流程?坐飞机

    现在机票越来越便宜,很多时候打折机票比高铁动车还要划算,坐飞机出行也成了很多人的第一选择。但机场一般都比较大,登机流程也很繁琐,很多第一次坐飞机的人一进航站楼都不知道该干嘛!今天就我个人经验,给你们分…

    2022年10月2日
  • 吃红薯会发胖吗?吃红薯后直接胖了3斤

    红薯属于粗粮类的食物,味道甜甜的,深受人们喜欢,但是有的女生害怕吃红薯长胖,下面我们来看看红薯的热量高吗,红薯吃了会长胖吗。 红薯的热量高吗 不少人认为,红薯的热量很高,尤其是身体比较胖或是正在减肥中的…

    2022年11月30日
  • 小程序商城如何上架产品

    小程序商城上架产品,是每个商家必须要做的一件事,而这也是商家获得收益的基础。因此,小程序商城上架产品,必须要做到规范、有效,以达到最大的收益。那么,小程序商城如何上架产品呢? 一、确定产品类型 在小程序…

    投稿 2023年6月4日
  • 公务员面试难度大吗?公务员面试流程

    现在一步一步的给大家介绍一下公务员的整个考试流程。 整个流程分为:看公告选岗——笔试准备——面试准备——体检——政审。 ——第一步:报名选岗 1.三不限的岗位尽量不要选 善用双学位/辅修专业,大学学的双学位、 辅修专业…

    投稿 2022年12月4日
  • 苹果手机如何电话录音?iphone手机通话录音

    分享最实在的玩机技巧,洞察最前沿的科技资讯!大家好,这里是手机科技园! 最近有很多朋友问我,为什么新买的苹果手机,没有找到录音机?其实它叫语音备忘录,下面就教带大家如何快速开启录音功能。 首先打开苹果手…

    2021年11月11日
  • 正确朗读26个拼音字母

    汉语拼音字母表-声母表语中每个音节起始处的辅音可以构成声母。汉语拼音方案《声母表》规定的声母符号一共有23个。 正确朗读26个拼音字母 b [玻] p [坡] m [摸] f [佛] d [得] t [特] n [讷] l [勒] g [哥] k [科] h…

    投稿 2023年12月24日