超时设置,以及超时监听
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前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
戳我获取!!**](https://bbs.csdn.net/topics/618191877)
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!