Ajax请求超时与网络异常处理图文详解

 更新时间:2021年05月23日 12:36:41   作者:追逐那颗星  
最近在项目中遇到一个问题,当加载数据量特别大的时候会出现加载超时现象,所以这篇文章主要给大家介绍了关于Ajax请求超时与网络异常处理的相关资料,需要的朋友可以参考下

别用IE浏览器!!!

问题

当浏览器请求超时或者网络异常的时候,我们程序需要做出什么处理和反应呢?

ps:代码我会在后面贴出来,思路最重要

# 请求超时 首先在==express==逻辑上是这样子写的

// 模拟请求超时
app.all("/delay", (request, response) => {
    response.setHeader('Access-Control-Allow-Origin', '*');
    response.setHeader('Access-Control-Allow-Headers', '*');

    setTimeout(() => {
        response.send('接收成功:模拟请求超时');
    }, 3000);
})

前端的请求

在这里插入图片描述

一开始没有加请求时间的设置,是可以输出结果的

在这里插入图片描述

那么现在呢,我们需要为请求加上一个限制时间,超过这个限制时间,浏览器就会认为此时请求超时了。如下加上

在这里插入图片描述

保存代码,然后到浏览器刷新,打开控制台

在这里插入图片描述

选择network,然后点击按钮,观察network的请求状态

首先一开始是pending状态(请求中)

在这里插入图片描述

超过了请求的阈值(2s),此时显示请求被取消了,显示cancel状态,而不是finish

在这里插入图片描述

但是在实际业务中,你不可能让每个用户打开控制台看请求有没有超时吧,所以我们可以加一个请求超时回调来完成信息弹窗提醒

在这里插入图片描述

我们刷新运行,发现此时就有一个弹窗提示了

在这里插入图片描述

那么,请求超时就演示到这来

网络异常

现在来看看网络异常我们需要怎么处理,那么网络异常在前端js里面也是有回调函数的,如下

在这里插入图片描述

然后,我们通过浏览器的控制台模拟离线状态

在这里插入图片描述

然后,我们点击按钮查看效果

在这里插入图片描述

莫得问题!

代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8" />
    <titile>超时与网络异常处理</titile>
    <style>
        #content {
            width: 400px;
            height: 200px;
            border: 1px solid rgb(4, 247, 25);
            border-width: 3px;
            margin: 20px 0 20px 0;
        }
    </style>
</head>

<body>
    <button type="button">提交</button>
    <div id="content"></div>
    <script>
        const btn = document.getElementsByTagName('button')[0];
        const res = document.getElementById('content');
        btn.onclick = function() {

            const xhr = new XMLHttpRequest();
            xhr.timeout = 2000;

            xhr.ontimeout = function() {
                alert('请求超时,请检查网络是否可用!');
            }

            xhr.onerror = function() {
                alert('你的网络开小差了,请重新连接网络试试');
            }

            xhr.open('GET', 'http://127.0.0.1:8080/delay');

            xhr.send();

            xhr.onreadystatechange = function() {
                if (xhr.readyState === 4) {
                    if (xhr.status >= 200 && xhr.status < 300) {
                        res.innerHTML = xhr.response;
                    }
                } else {

                }
            }
        };
    </script>
</body>

</html>
const express = require("express");

const app = express();

// 模拟请求超时
app.all("/delay", (request, response) => {
    response.setHeader('Access-Control-Allow-Origin', '*');
    response.setHeader('Access-Control-Allow-Headers', '*');

    setTimeout(() => {
        response.send('接收成功:模拟请求超时');
    }, 3000);
})

app.listen(8080, () => {
    console.log('正在监听8080端口');
});

总结

到此这篇关于Ajax请求超时与网络异常处理的文章就介绍到这了,更多相关Ajax请求超时内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Ajax实现异步用户名验证功能

    Ajax实现异步用户名验证功能

    当用户填写好账号切换到密码框的时候,使用ajax验证账号的可用性。这篇文章就主要为大家详细介绍了Ajax实现异步用户名验证功能,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • [js]一个获取页面ip的正则

    [js]一个获取页面ip的正则

    [js]一个获取页面ip的正则...
    2007-07-07
  • ajax以及一些乱码问题

    ajax以及一些乱码问题

    很就以前在使用AJAX的时候,那时候还不知道AJAX。于是在任务中被AJAX的乱码问题搞的头破血流。
    2010-08-08
  • ajax数据传输方式实例详解

    ajax数据传输方式实例详解

    这篇文章主要介绍了ajax数据传输方式,结合实例形式较为详细的分析总结了ajax数据传输的原理与传输文本、xml及json格式数据的具体实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-12-12
  • Ajax Session失效跳转登录页面的方法

    Ajax Session失效跳转登录页面的方法

    这篇文章主要介绍了Ajax Session失效跳转登录页面的方法,非常不错具有参考借鉴价值,感兴趣的朋友一起看下吧
    2016-06-06
  • jquery ajax提交表单从action传值到jsp实现小结

    jquery ajax提交表单从action传值到jsp实现小结

    pw.print(random);这里的random就是action要向jsp传的值,在jsp中,success: function(text)这里的text就是接收从action传过来的值,感兴趣的朋友可以参考下哈
    2013-04-04
  • ajax JSONP请求处理回调函数jsonpCallback区分大小写

    ajax JSONP请求处理回调函数jsonpCallback区分大小写

    使用ajax进行 JSONP跨域请求,因为被请求的对方的回调函数名称是无法修改,想到设置AJAX 的JSONP参数。但是发现根本不起作用。最后偶然发现 jsonpcallback是区分大小写的
    2013-09-09
  • Ajax长连接项目案例

    Ajax长连接项目案例

    所谓的长连接,就是不断去发送请求,把请求阻塞在服务器端,每次超过请求时间就去重新发送请求,下面以一个实例为大家详细介绍下,感兴趣的朋友可不要错过了哈
    2013-08-08
  • ajax问题总结 比较全

    ajax问题总结 比较全

    在看文章前,先指定一个变量xhr,xhr代表ajax对象。测试浏览器:ie为ie6,firefox为2,其他的未测试。统称ie6为ie,firefox2为ff。
    2011-01-01
  • ajax处理服务器返回的三种数据类型方法

    ajax处理服务器返回的三种数据类型方法

    这篇文章主要介绍了ajax如何处理服务器返回的三种数据类型,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10

最新评论