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


超时设置,以及超时监听

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事件。

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

1、根据IP协议,判断目的IP和源IP是否属于同一个子网(将源IP和子网掩码按位与即可)

2、根据ARP协议,找到目的IP对应的mac地址(查询ARP表,广播ARP请求,找到对应的目的主机)

3、根据路由协议,找到最佳网络传输路径(查询路由表)

所以,我们只能在2上做文章,即让服务器关闭,这样就找不到目的主机了。

最后

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

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

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

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
戳我获取!!**](https://bbs.csdn.net/topics/618191877)

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值