网站判断网络连接断开,js判断网络连接断开,最佳实践

借鉴:https://blog.csdn.net/ty497122758/article/details/26613775

思路:js没有判断网络断开的直接方法,通用的方法效果不好(只要在局域网就会判断为连接,无法严格的判断是否连接互联网)

特殊方法,使用js获取一张图片(百度的logo)但不会显示它,判断是否获取成功;需要注意,一般浏览器都会有缓存(文件名相同的资源不会重复加载),所以采取措施;图片文件后添加参数(由时间生成),让浏览器认为不是同一张图片。

话不多说,上代码

window.onload = function () { //网页加载完成便运行
    var nextValue = true; //用于决定是否下一次循环
    setInterval(function () { //定时循环,2秒一次
        if (nextValue == true) {
            var EventUtil = {
                addHandler: function (element, type, handler) {
                        if (element.addEventListener) {
                            element.addEventListener(type, handler, false);
                        } else if (element.attachEvent) {
                            element.attachEvent("on" + type, handler);
                        } else {
                            element["on" + type] = handler;
                        }
                    },
                    removeHandler: function (element, type, handler) {
                        if (element.removeEventListener) {
                            element.removeEventListener(type, handler, false);
                        } else if (element.detachEvent) {
                            element.detachEvent("on" + type, handler);
                        } else {
                            element["on" + type] = null;
                        }
                    }
            };
            var dom = document.createElement('img');
            dom.style = 'display:none;';
            dom.src = 'https://www.baidu.com/img/flexible/logo/pc/result.png';
            dom.src += '?t=' + (+new Date()); //图片文件后添加参数(由时间生成)
            dom.id = 'map_img';
            EventUtil.addHandler(dom, 'error', function () {
                swal({ //相当于alert,但更美观
                        title: "网络连接断开!",
                        text: "请检查网络连接!",
                        type: "error",
                        showCancelButton: true,
                        confirmButtonColor: "#DD6B55",
                        confirmButtonText: "我知道啦!",
                        cancelButtonText: "暂不提醒!",
                        closeOnConfirm: true,
                        closeOnCancel: true
                    },
                    function (isConfirm) {
                        if (isConfirm) {} else {
                            nextValue = false;
                        }
                    });
            });
            document.body.appendChild(dom);
        }
    }, 2000);
};

swal提供更美观的弹出框,需要导入css和js:
https://uosblog.top/ZBXYDYFX/js/sweetalert-dev.js
https://uosblog.top/ZBXYDYFX/css/sweetalert.css
建议引入到您的网站上

还需要引入https://code.jquery.com/jquery-3.6.0.min.js

swal更多使用方式http://mishengqiang.com/sweetalert/

效果:
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 C++ 中判断网络连接是否断开可以通过以下步骤实现: 1. 使用 WinSock 库提供的函数创建一个套接字(Socket)。 2. 调用 connect 函数连接服务器。 3. 调用 select 函数监视套接字上的读事件和写事件,如果返回值大于 0 则表示有事件发生。 4. 调用 recv 函数接收数据,如果返回值小于等于 0 则表示连接已经断开。 以下是一个简单的示例代码: ```c++ #include <winsock2.h> #include <iostream> #pragma comment(lib, "ws2_32.lib") int main() { WSADATA wsaData; if (WSAStartup(MAKEWORD(2, 2), &wsaData) != 0) { std::cerr << "WSAStartup failed\n"; return 1; } SOCKET s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (s == INVALID_SOCKET) { std::cerr << "socket failed\n"; return 1; } sockaddr_in addr; addr.sin_family = AF_INET; addr.sin_port = htons(80); addr.sin_addr.s_addr = inet_addr("192.168.1.1"); if (connect(s, (sockaddr*)&addr, sizeof(addr)) == SOCKET_ERROR) { std::cerr << "connect failed\n"; closesocket(s); WSACleanup(); return 1; } fd_set readfds, writefds; timeval timeout; timeout.tv_sec = 5; timeout.tv_usec = 0; while (true) { FD_ZERO(&readfds); FD_ZERO(&writefds); FD_SET(s, &readfds); FD_SET(s, &writefds); int ret = select(0, &readfds, &writefds, NULL, &timeout); if (ret == SOCKET_ERROR) { std::cerr << "select failed\n"; break; } else if (ret == 0) { std::cout << "timeout\n"; break; } else { if (FD_ISSET(s, &readfds)) { char buf[1024]; int len = recv(s, buf, sizeof(buf), 0); if (len <= 0) { std::cout << "connection closed\n"; break; } } if (FD_ISSET(s, &writefds)) { // do something } } } closesocket(s); WSACleanup(); return 0; } ``` 以上代码中的 IP 地址和端口号需要根据实际情况进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Deng_Xian_Shemg

捐助1元钱

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值