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年10月6日
  • apk加固是什么意思(apk加固了解)

      转载本文需注明出处:微信公众号EAWorld,违者必究。  在安卓开发中,打包发布是开发的最后一个环节,apk是整个项目的源码和资源的结合体;对于懂点反编译原理的人可以轻松编译出apk的源码资源,并且可以修改资源代码、重新打包编译,轻轻松松变成自己的apk或者修改其中一部分窃取

    2022年1月10日
  • 网络直播教育平台?如何做直播教育

    在前不久,很多在线教育机构转型职业教育,很大原因是国家支持大力发展职业教育,而且很多城市考取职业教育培训证件也可以获得补贴。同时,疫情和不一的工作时间就让人们不得不寻找线上平台来学…

    2021年11月13日
  • 小学生护脊书包品牌十大排名

    书包是学生必备的学习用品之一。市场上的书包品牌形形色色,质量也是参差不齐,消费者选购的时候也是眼花缭乱。近期,在广东省消费者委员会的指导下,珠海市消费者权益保护委员会联合澳门特别行…

    2024年1月21日
  • 打工不如创业(打工不如创业经典说说)

    作者丨焱公子编辑丨水青衣朋友老魏在一家互联网公司做中层管理,平常加班很多。上周好容易得空一起吃顿饭,他边吃边吐槽自己太难了。“经常加班到凌晨,老板这不满意那不满意的,老婆还嫌我工资低……”另一个朋友撺掇他:“既然这样,出来自己干啊,那就不用看谁脸色了。”老魏一声长叹:“不是没

    2022年1月1日
  • 龙之谷机械大师刷图加点(龙之谷机械大师pk加点)

    机械大师刷图的时候感觉费力吗,比别的职业明显鸡肋很多,那就是你技能加点错啦,龙之谷手游机械大师刷图技能加点跟pk加点还是有一定差距,选对技能加点很重要,一起来了解一下吧。 龙之谷手…

    2022年10月14日
  • 腊肉怎么做好吃?腊肉最简单的吃法

    自古民间就有“冬腊风腌,蓄以御冬”的习惯,小雪前后,温度骤降、空气干燥,正是腌腊肉、灌腊肠的好时候,我家每年这个时候都会腌上10斤、20斤,等到过年腊味醇厚、咸香流油,左右邻居都闻…

    2022年12月8日
  • 莫高窟在哪里?敦煌在哪里

    敦煌莫高窟 ,俗称千佛洞,中国4大石窟之一,世界文化遗产,位于中国甘肃省敦煌市东南25公里处的呜沙山东麓断崖上 。始建于十六国的前秦时期。前秦建元二年(西元366)年,僧人乐僔路经…

    2022年11月29日
  • 地摊火爆产品有哪些?地摊产品

    今天就为大家来介绍一下我总结的摆摊经验。今天献给讲讲大的品类,下一篇文章教大家怎么选择适合自己的具体商品。 1、饰品和化妆品 都说女人的生意好做,那女人谁不喜欢小饰品呢?而且饰品化…

    2022年10月22日
  • 天猫精灵怎么连接手机(天猫精灵连接手机热点教程)

    天猫精灵可以通过蓝牙与手机建立连接,先到应用市场下载“天猫精灵APP”,然后打开手机蓝牙,接通“天猫精灵”电源,打开“天猫精灵APP”,对天猫精灵说:“天猫精灵,蓝牙连接”, 听到…

    2021年11月2日