前端网络基础-通过XMLHttpRequest实现AJAX (二)

超时设置,以及超时监听

取消HTTP请求

HTTP请求发生异常(网络异常)

HTTP正常请求响应过程中的事件


超时设置,以及超时监听

xhr对象上有一个timeout属性,用于设置xhr发起的HTTP请求的超时时间,单位毫秒。

默认值为0,表示无超时设置。

xhr.timeout不等于0,由请求开始即onloadstart开始算起,当到达xhr.timeout所设置时间请求还未结束即onloadend,则表示超时

当xhr对象发起的HTTP请求超时了,则会被浏览器监听到,浏览器会触发xhr对象上ontimeout事件处理程序,并自动取消xhr发起的HTTP请求。

注意:ontimeout事件处理程序执行完后,才会自动取消xhr发起的HTTP请求。

而不是ontimeout事件一触发,就自动取消HTTP请求。

所以,当ontimeout事件处理程序执行慢时,很有可能在此期间HTTP响应已经完成,所以也就无法取消HTTP请求了。

如上图,服务器响应在1000ms后,xhr请求超时在500ms后,理论上,应该会立即超时并cancel http request,但是ontimeout事件处理程序中使用了alert,而alert执行结束需要用户点击弹窗的确认,所以当用户点击慢了,即超过500ms还没点击,服务器就已经完成HTTP响应,所以之后也就不会发生cancel http request了。

取消HTTP请求

前面当xhr设置了超时后,如果发生HTTP请求超时,则会自动取消HTTP请求。那么如何实现可控的取消HTTP请求呢?

xhr对象上有一个abort方法,调用该方法就会取消xhr发起的HTTP请求。并且配套了取消HTTP请求的事件监听处理程序,即xhr.onabort。

需要注意的是xhr.abort()调用后,必须等xhr.onabort事件处理程序执行完,才会取消xhr发起的HTTP请求。

如果xhr.onabort事件处理程序执行完之前,HTTP响应了,则无法再取消。

HTTP请求发生异常(网络异常)

xhr对象上有一个onerror的事件监听处理程序属性,浏览器监听到xhr发起HTTP请求发生错误就会触发xhr.onerror事件监听处理程序。

注意,只有发生了网络层级别的异常才会触发此事件,对于应用层级别的异常,并不属于Network error,所以不会触发onerror事件,而是会触发onload事件。

如何模拟网络层异常呢?我们需要知道网络层干了什么事?

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

后记


总结一下这三次面试下来我的经验是:

  1. 一定不要死记硬背,要理解原理,否则面试官一深入就会露馅!

  2. 代码能力一定要注重,尤其是很多原理性的代码(之前两次让我写过Node中间件,Promise.all,双向绑定原理,被虐的怀疑人生)!

  3. 尽量从面试官的问题中表现自己知识的深度与广度,让面试官发现你的闪光点!

  4. 多刷面经!

我把所有遇到的面试题都做了一个整理,并且阅读了很多大牛的博客之后写了解析,免费分享给大家,算是一个感恩回馈吧,有需要的朋友【点击我】获取。祝大家早日拿到自己心怡的工作!

篇幅有限,仅展示部分内容



mg-blog.csdnimg.cn/img_convert/b871b45fb2e6d5442144c863cbcff965.png)

  • 28
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值