超时设置,以及超时监听
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前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
前端面试题是我面试过程中遇到的面试题,每一次面试后我都会复盘总结。我做了一个整理,并且在技术博客找到了专业的解答,大家可以参考下:
由于篇幅有限,只能分享部分面试题,完整版面试题及答案可以【点击我】阅读下载哦~
感悟
享部分面试题,完整版面试题及答案可以【点击我】阅读下载哦~**
感悟
春招面试的后期,运气和实力都很重要,自己也是运气比较好,为了回馈粉丝朋友们(毕竟自己也玩了这么久哈哈哈),整理个人感悟和总结以上。最后祝愿大家能够收获理想offer!!