前端网络基础-通过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%以上前端开发知识点,真正体系化!

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

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

前端面试题汇总


前端面试题是我面试过程中遇到的面试题,每一次面试后我都会复盘总结。我做了一个整理,并且在技术博客找到了专业的解答,大家可以参考下:

由于篇幅有限,只能分享部分面试题,完整版面试题及答案可以【点击我】阅读下载哦~

感悟

享部分面试题,完整版面试题及答案可以【点击我】阅读下载哦~**

感悟

春招面试的后期,运气和实力都很重要,自己也是运气比较好,为了回馈粉丝朋友们(毕竟自己也玩了这么久哈哈哈),整理个人感悟和总结以上。最后祝愿大家能够收获理想offer!!

  • 19
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值