前言

这篇文章主要聊一聊如何手写一个jquery的ajax方法,这是前端中的基础知识,也是一道非常经典的前端面试题!

一步步手写ajax

在web页面中与后端通信的顺序一般都是客户端向服务器发起请求,然后服务器再回复客户端,用于通信的工具就是ajax。如果你喜欢足球,你肯定知道荷甲联赛中也有一支豪门足球俱乐部叫阿贾克斯,名字一毛一样。ajax就像电话一样,将页面和服务器联系在一起,基本用法如下:

图1

从图1中我们可以看出$.ajax是一个函数,它的参数是一个对象,那么我们可以像如下这样定义:

var $ = {}; // 模拟jquery对象$.ajax = function(options){// 实现逻辑}

接下来我们就开始写函数里面的逻辑。

图2

如图2,ajax的关键在于XMLHttpRequest对象,它提供了对http协议的安全访问接口,这里使用了它的两个方法和一个事件:

1)open方法的第一个参数是请求类型:get、post、head等,第二个参数是请求的接口地址,第三个参数表示ajax请求是异步(true)还是同步(false),如果是异步,在ajax发送完请求后js会继续执行,不会等待服务器响应,我们一般选择异步,提高页面的渲染效率;

2)send方法只有一个参数,表示向服务器发送的参数,一般是对象;

3)onreadystatechange是一个事件,它可以监听从请求开始到结束整个过程的状态,状态保存在xhr的readyState属性中。

readyState状态:

  • 0代表未初始化,open方法还未执行;
  • 1代表正在加载,open已被执行但send还未被执行;
  • 2代表已经加载完毕,send已被执行,请求已被发送;
  • 3代表正在等待服务器响应;
  • 4代表响应已经完成。

从上面readyState状态我们可以看出,ajax只需要4的情况,其他状态其实都是失败!

另外,xhr的status属性代表服务器返回的状态码,根据我们的经验,状态码在400以上都是有问题的,要么是服务端问题,要么就是客户端问题!300到400之间好像都和重定向有关系,但是有一个除外——304,如果你了解浏览器缓存,你肯定知道它和协商缓存有关系,其实它代表请求成功!另外200以下的状态都需要请求者继续操作,也不符合要求!总结一下,可用的状态码就是200到300之间,加一个304!

好了,经过上面的分析,我们继续完善onreadystatechange事件的处理函数:

图3

如图3,在事件处理函数中我们写了两个方法ajaxSuccess和ajaxError,它们分别执行ajax参数对象传入的success和error这两个函数属性。我们知道ajax对象参数中还一个属性叫complete,这是一个方法,无论请求成功与否,它都会被执行,所以它在ajaxSuccess和ajaxError中都需要被调用执行一次。xhr.responseText代表服务器返回的数据,xhr.statusText代表状态码对应的状态信息。

接下来我们还需要设置请求头,可以用xhr.setRequestHeader来完成,如下:

图4

图4中,我们对两个比较特殊的请求头做了默认设置(Accept和Content-type),其中当我们用post类型向服务器发送请求并且带有参数,此时content-type需要设置为application/x-www-form-urlencoded,其他的请求头可以通过ajax的对象参数headers属性传入。注意setRequestHeader方法需要在open方法之后调用!

在有些场景下,我们需要在发送请求前做一些逻辑判断,如果不满足条件我们需要阻止请求的发送,为了满足需求,我们需要在ajax调用open方法之前添加一个钩子!

图5

图5中我们通过beforeSend函数的执行结果判断是否需要取消请求!

写到这里其实还有一步没做,那就超时逻辑,比如在网络不好的情况下,我们不能让页面一直处于loading状态,需要设置一个超时时间,超过这个时间就代表ajax请求失败!开发超时的需求,我们最容易想到的是利用定时器setTimeout,现在我们补上!

图6

如图6,在超时的情况下,我们将onreadystatechange事件处理函数置为一个空函数并且放弃这次请求,然后执行error函数,另外在正常的onreadystatechange事件处理逻辑中我们需要及时清除这个定时器!

写到这里,一个简单的ajax就已经开发完了,现在直接把demo拿去使用也是没有问题的!

常见面试题

1、手写一个ajax?

如果你看到这里我想应该没什么问题了!

2、如果请求发生了重定向,ajax会怎么处理?

当然是进入了error函数中!

3、如果请求发生了超时,ajax会怎么处理?

当然也是进入了error函数中!

总结

本篇文章手写的ajax可以直接用于移动端,未考虑PC端兼容性!根据我的经验,只要能手写出ajax,面试中遇到相关问题就不会被难住,此类问题其实就是送分题!另外多说一点,开发PC页面时我们使用的是jquery,而开发移动端时我们应该使用zepto.js!本篇文章就写到这里,下一篇接着写JSONP的实现!

喜欢我的文章就关注我吧,有问题可以发表评论,我们一起学习,共同成长!

jquery $.post 超时_详解如何实现前端jquery中的ajax方法,看这一篇就够了相关推荐

  1. 关于python语言的浮点数类型_Python 浮点数数据类型详解(float)[学习 Python 必备基础知识][看此一篇就够了]...

    原博文 2020-04-20 15:25 − > 您的"关注"和"点赞",是信任,是认可,是支持,是动力...... > 如意见相佐,可留言. &g ...

  2. python复数类型转换_Python 复数数据类型详解(complex)[学习 Python 必备基础知识][看此一篇就够了]...

    您的"关注"和"点赞",是信任,是认可,是支持,是动力...... 如意见相佐,可留言. 本人必将竭尽全力试图做到准确和全面,终其一生进行修改补充更新. 1 复 ...

  3. vue动态设置文字布局方式_详解Vue动态添加模板的几种方法

    动态添加模板需要收集原始数据的页面,这个时候我们需要很多原始数据收集模板,下面给大家详解Vue 动态添加模板的几种方法,希望对你学习这方面知识有所帮助. 通常我们会在组件里的 template 属性定 ...

  4. python比较两个字符串相似度_详解Python 字符串相似性的几种度量方法

    字符串的相似性比较应用场合很多,像拼写纠错.文本去重.上下文相似性等. 评价字符串相似度最常见的办法就是:把一个字符串通过插入.删除或替换这样的编辑操作,变成另外一个字符串,所需要的最少编辑次数,这种 ...

  5. Docker的mysql镜像_详解docker下的Mysql镜像的使用方法

    通常初学者学习docker时,不太清楚怎样拉取一个Mysql镜像并使用,今天这篇文章简单介绍一下使用流程. 一.预习一下用到的docker命令: 1.docker images 列出本地主机上的镜像. ...

  6. mysql教程详解之多表联合查询_详解数据库多表连接查询的实现方法

    详解数据库多表连接查询的实现方法 通过连接运算符可以实现多个表查询.连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志. 在关系数据库管理系统中,表建立时各数据之间的关系不必 ...

  7. python中setattr用法_详解Python的hasattr() getattr() setattr() 函数使用方法

    hasattr(object, name) 判断一个对象里面是否有name属性或者name方法,返回BOOL值,有name特性返回True, 否则返回False. 需要注意的是name要用括号括起来 ...

  8. jquery中的ajax方法参数——$.ajax()方法详解

    1.url:  要求为String类型的参数,(默认为当前页地址)发送请求的地址. 2.type:  要求为String类型的参数,请求方式(post或get)默认为get.注意其他http请求方法, ...

  9. mysql grep 提取错误日志_详解grep获取MySQL错误日志信息的方法

    为方便维护MySQL,写了个脚本用以提供收集错误信息的接口.这些错误信息来自与MySQL错误日志,而 通过grep mysql可以获取error-log的路径. 以下是全部相关代码: #!/usr/b ...

  10. can协议crc计算_详解CAN/CAN FD通信中的循环冗余校验(CRC)方法

    数据校验是为保证数据的完整性进行的一种验证操作.CAN通信采用CRC校验作为一种重要的错误检测手段,是节点判断CAN帧信息的完整性并产生确认应答的依据. 在现场总线通信和控制的实际应用中,工业应用环境 ...

最新文章

  1. R语言可视化学习笔记之相关矩阵可视化包ggcorrplot
  2. 《PHP精粹:编写高效PHP代码》——2.1节数据持久化和Web应用程序
  3. int*p[ ]与int(*p)[ ]的不同
  4. 网络推广策略带你了解网站地图Sitemap的作用是什么?
  5. 项目分析(map复习)
  6. dbi mysql_DBI和DBD-mysql模块的安装_MySQL
  7. auto与迭代器的用法_C++ STL move_iterator移动迭代器用法详解
  8. oracle 内部表连接方式,ORACLE 表连接方式
  9. c# 正则表代式的分组和批评模式 .
  10. 云南昭通暴雨强度公式_玉溪市中心城区暴雨强度公式(修订)
  11. android局域网调试无法安装,真机调试出现:INSTALL_FAILED_USER_RESTRICTED 安装错误解决方案...
  12. Silverlight入门
  13. oracle exists替换,oracle 优化or 替换为in、exists、union all的几种写法,测试没有问题!...
  14. 笔记本电脑摄像头频闪问题,打开摄像头出现错误代码0xA00F4244(0xC00D36D5)的问题解决方法
  15. linux下如何查看cpu温度
  16. U8-存货结存数量与序列号可用数量不一致
  17. CSDN验证不了手机
  18. torchvision.transforms.ColorJitter函数详解
  19. Chrome 使用绿色版实现同一个机器 打开多个不同的chrome版本
  20. clear:both在HTML页面中的用法

热门文章

  1. asp.net core跨域访问ajax的验证访问
  2. 基于jQuery UI CSS Framework开发Widget
  3. 365Key今天不能用了,感觉不爽
  4. ssh公钥的生成、查看以及config的配置
  5. linux 去掉csv文件第一行,使用PowerShell删除文本文件的第一行
  6. insert into select from要注意什么_老外说put two and two together什么意思?是2+2?
  7. curl basic 认证
  8. java struts 读取文件_读取文件.txt并将其保存到c中的struct
  9. mysql 行显示 g_MySQL行(记录)详细操作
  10. String类型相关的题