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

相关推荐

  • qq聊天信息如何删除彻底删除(如何删除qq聊天记录)

    怎样彻底删除手机qq聊天记录,其实很简单,只要不同步到电脑, 就可以在手机上面值删除;一起来看看吧 1、登陆你的手机QQ,在消息界面中点击你的QQ 头像;就会进入到设置界面;点击设…

    2022年12月4日
  • cdr格式怎么用ai打开?cdr文件用什么打开

    今天给大家分享 “没有cdr软件怎么打开cdr文件?” 一天小李收到某广告公司发给自己的产品包装设计方案,但是小李怎么也打不开,后来才发现发来的文件是cdr格式的矢量图,正常cdr…

    2022年12月28日
  • 先锋刻录机怎么用?先锋刻录机

    相信许多DIY用户已经很久没有接触光驱了,近十年来,基本没有用户会在装机的时候考虑购买一个内置光驱。事实上,仍有厂商在生产内置光驱,并没有间断过,除了满足一些商用客户的需求外,个别…

    2022年10月16日
  • 胡萝卜汁怎么做最好喝?做胡萝卜汁

    胡萝卜和苹果都是营养丰富的蔬菜水果水果。胡萝卜的营养成分之丰富,具有保护眼睛、通便等功效。而苹果富含矿物质和维生素,而且营养可溶性大,容易被人体吸收,有利于溶解硫元素,使皮肤润滑柔…

    2022年12月29日
  • 高性能笔记本电脑推荐?口碑最好的笔记本电脑

    最近收到好多网友的私信,大概都是询问最近惠普电脑哪一款值得买? 其实,惠普电脑拥有多个系列,包括游戏系列(暗影精灵7、光影精灵7等)、战系列(战X、战66等)、轻薄系列(惠普星14…

    2021年11月7日
  • 房间装修设计韩系?装修房间分享

    在装修家的时候,相信我们都会想把家装的满满的,让它更有人情味。但是最近,极简风也正成为一种流行。让家空空荡荡的,也有别样的美感。 今天就来给大家分享一个极简风的家装。虽然家具和硬装…

    2021年11月3日
  • 红薯怎么做好吃?红薯怎样炒好吃又简单

    红薯是一种好种植且产量极高的农作物,现在红薯的品种也多,就拿一般的品种来说,一亩地能产1万多斤。60岁以上,像我们的父辈他们小时候就是以红薯为主食的。现在还经常从老一辈的口中听到:…

    2022年12月2日
  • ccleaner好用吗(Windows电脑中实用性特别强的9款软件)

    对于一些对电脑不是非常了解的小伙伴们来说,经常会下载一些实用性非常低

    2022年1月2日
  • (农村题材的电视剧推荐)农村题材的电视剧

    仅凭着一群“灰头土脸”的演员,讲述了一段“土里土气”的故事,便成为了年度剧王。 它就是去年播出的主旋律大剧《山海情》。 乡村题材的电视剧,总是离不开一个“真”字。 人物鲜活、生动、…

    2022年10月6日
  • 超纤皮是一种什么材质?超纤皮和真皮图片对比

    买车的时候,销售说自己的车座椅是真皮座椅,真的可信吗?真皮座椅到底有多“真”?如何鉴定是否为真皮座椅呢?看完这篇文章,很多车主都去检查自己爱车了! 皮座椅,是很多车主买车的时候,都…

    2022年11月20日