AJAX的一些常见问题处理

简介: AJAX常见一些问题的处理在用户体验中,可能会存在这样的问题,当服务器半天没有返回数据的时候,用户可能会多次进行请求。这就会导致浏览器增加许多的请求,这样就会导致服务器的压力增大,而且用户体验也会变差。

AJAX常见一些问题的处理

在用户体验中,可能会存在这样的问题,当服务器半天没有返回数据的时候,用户可能会多次进行请求。这就会导致浏览器增加许多的请求,这样就会导致服务器的压力增大,而且用户体验也会变差。

1. 取消请求

当用户多次点击按钮的时候,会导致浏览器发送多次请求,这样就会导致服务器压力增大,而且用户体验也会变差。

为了解决这个问题,就需要将用户多与的请求给取消掉,只保留第一次请求。

这样就可以极大的缓解服务器的压力,而且用户体验也会变好。

1.1 代码实现

btn.onclick = function(){
    // 1. 创建XMLHttpRequest对象
    var xhr = new XMLHttpRequest();
    // 2.取消请求
    xhr.abort();
}
复制代码

上面的代码中,我们只需要在发送请求之前,调用abort()方法就可以了。

也就是说,我们如果要取消用户的请求,只需要使用abort()方法,这个方法是XMLHttpRequest对象自带的方法。

2. 超时处理

当然实际的情况往往是很复杂的,也就会出现这样一种情况,当用户点击按钮发送请求之后,因为服务器的问题,很久都没有返回数据。但是我们不能让用户一直干等着。

这个时候,我们就需要给用户一个提示,告诉用户,服务器没有返回数据,你可以等待,也可以取消。

这个时候我们使用timeout属性就可以了。

2.1 代码实现

const xhr = new XMLHttpRequest;
    // 设置超时时间 超过时间不响应  取消请求
    xhr.timeout = 2000;
    // 超时处理
    xhr.ontimeout = function(){
        console.log('请求超时');
    };
    // 网络异常回调
    xhr.onerror = function(){
        console.log('网络异常');
    };
复制代码

代码解释:

上面的代码中我们通过timeout属性设置了超时时间,当超过这个时间的时候,就会触发ontimeout事件。当用户因为网络问题导致不能正常请求的时候,就会触发onerror事件。

timeout属性是用来设置超时时间的,单位是毫秒。

ontimeout属性是用来设置超时处理的。在这个事件中,我们可以做一些处理,比如提示用户,服务器没有返回数据。

onerror属性是用来设置网络异常处理的。在这个事件中,我们可以做一些处理,比如提示用户,网络异常。

结尾

本文主要讲解了XMLHttpRequest对象的取消请求和超时处理。


相关文章
|
JavaScript 前端开发 数据可视化
哪些 JS 框架支持 SPA 单页面应用
目前主流的JavaScript框架如React、Vue和Angular都支持SPA(单页面应用)开发,能够实现页面无刷新更新,提升用户体验。其他如Ember.js、Backbone.js等也具备SPA开发能力。
|
网络协议 安全 算法
网络空间安全之一个WH的超前沿全栈技术深入学习之路(9-2):WireShark 简介和抓包原理及实战过程一条龙全线分析——就怕你学成黑客啦!
实战:WireShark 抓包及快速定位数据包技巧、使用 WireShark 对常用协议抓包并分析原理 、WireShark 抓包解决服务器被黑上不了网等具体操作详解步骤;精典图示举例说明、注意点及常见报错问题所对应的解决方法IKUN和I原们你这要是学不会我直接退出江湖;好吧!!!
|
安全 网络安全 文件存储
思科设备巡检命令Python脚本大集合
【10月更文挑战第18天】
513 1
思科设备巡检命令Python脚本大集合
|
机器学习/深度学习 缓存 Java
javax异常: javax.imageio.IIOException: Can't create output stream解决方法
javax异常: javax.imageio.IIOException: Can't create output stream解决方法
|
运维 负载均衡 监控
同时设置两张网卡的接口跃点数:影响与优化分析
在现代网络中,服务器常配有多张网卡以提升性能和冗余。本文探讨了不同跃点数配置的影响及优化策略。首先介绍了跃点数的概念及其对数据传输效率的影响。接着分析了两张网卡跃点数差异可能导致的延迟增加、负载不均衡等问题,并提出了负载均衡、优先级设置、监控调整及故障转移等优化方法,帮助网络管理员实现高效稳定的通信。
|
存储 ice 索引
经验大分享:PJSUA2开发文档
经验大分享:PJSUA2开发文档
379 0
|
Linux 开发工具 Android开发
Flutter之搭建环境
Flutter之搭建环境
|
存储 数据安全/隐私保护 iOS开发
如何在阿里云ACK安装Kubecost
背景工作需要研究kebecost,正好也看到阿里云ACK集成了kubecost的推送,想着装个研究研究。本文中依据Kubecost的文档:https://docs.kubecost.com/install-and-configure/install/provider-installations/alibaba-install 安装,文档寥寥几句看似容易,但是实际装起来坑还是蛮多的,这里记录一下以便
979 1
如何在阿里云ACK安装Kubecost
|
存储 数据采集 分布式计算
大数据治理系列:6 如何保护大数据的安全和隐私
从安全和隐私的角度来看,大数据与其他传统数据不同,需要不同的方法。但是可以扩展许多现有的方法和实践,以支持大数据的安全和隐私模式。
大数据治理系列:6 如何保护大数据的安全和隐私
|
前端开发 Java 数据库连接
Spring Boot+MyBatis+Redis+ActiveMQ+MySQL+Thymeleaf实现简单的高并发点赞功能(上)
Spring Boot+MyBatis+Redis+ActiveMQ+MySQL+Thymeleaf实现简单的高并发点赞功能
591 1
Spring Boot+MyBatis+Redis+ActiveMQ+MySQL+Thymeleaf实现简单的高并发点赞功能(上)