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对象的取消请求和超时处理。


相关文章
|
7月前
|
JSON 前端开发 JavaScript
Ajax的一种替代方式
演示了两种方式执行Ajax请求:传统的jQuery方法,包括设置URL、类型、数据类型、数据及回调函数;以及现代的fetch API,使用async/await处理POST请求,检查响应状态并转换为JSON。
53 1
|
5月前
|
XML JSON 前端开发
Ajax 概述
Ajax 概述
33 0
N..
|
8月前
|
XML JSON 前端开发
Ajax概述
Ajax概述
N..
97 0
|
8月前
|
XML JSON 前端开发
Ajax 是什么? 如何创建一个 Ajax?
Ajax 是什么? 如何创建一个 Ajax?
56 0
|
前端开发
Ajax基本案例详解之$.get的实现
前面我已经写过一篇ajax的$.ajax的实现了,其中html,css,doindex.jsp里面已经详细列出来了,这篇主要写的是$.get()的实现,其中html,css,doindex.jsp都和Ajax基本案例详解之$.get的实现 里面的一样,所以这里就不重复的写了,在这里只写一下<script>里面的内容就行
|
前端开发 UED 开发者
如何使用 Ajax?
Ajax 可以使Web应用更加迅捷动态化
118 0
|
Web App开发 前端开发 JavaScript
使用AJAX基本步骤
使用AJAX基本步骤
179 0
使用AJAX基本步骤
|
XML JSON 前端开发
Ajax学习参考文档
Ajax学习参考文档
310 1
Ajax学习参考文档
|
XML 前端开发 JavaScript
什么是 Ajax? 如何创建一个Ajax?
什么是 Ajax? 如何创建一个Ajax?
|
前端开发 Java
【AJAX】AJAX技术详细解析以及实例(2)
【AJAX】AJAX技术详细解析以及实例
203 0
【AJAX】AJAX技术详细解析以及实例(2)