分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 网页技术

reconnecting-websocket.js

发布时间:2023-09-06 01:53责任编辑:彭小芳关键词:jswebsocket

websocket是HTML5下一个不错的网络协议解决方案,有一个场景很多猿猿都会遇到,手机锁屏后大约60秒,IOS会自动断开websocket连接,连接丢失了,那我们的数据也就断了。websocket 断线重连方案如下:

ReconnectingWebSocket

reconnecting websocket是一个javascript封闭的websocket库,非常小,压缩后仅有3KB。它的功能是当websocket断线后自动帮你重连。使用方法很简单:

只要把

var ws = new WebSocket(‘ws://....‘);

 替换成

var ws = new ReconnectingWebSocket(‘ws://....‘);

就行了,当websocket断开着它会帮你自动重连,socket永不断线!

它支持事件

onopenonmessageonmessageonmessageonclose // At this point the WebSocket instance is dead.

 websocket 断线重连原理实现

var ws = new WebSocket(‘ws:../../websocket‘);ws.onmessage = function(msg){ ???console.log(‘msg:‘,msg); ???//do something};ws.onclose = function(){ ???console.log(‘closed....‘);};

 实现websocket断线重连

var ws = new WebSocket(‘ws:../../websocket‘);ws.onmessage = function(msg){ ???console.log(‘msg:‘,msg); ???//do something};//把刚才干的事情重写一遍function reconnect (){ ???rews = new WebSocket(‘ws:../../websocket‘); ???rews.onmessage = function(){ ?????//dosomthing ?????}; ???rews.onclose = function(){ ???????//dosomthing ???};}//每隔5秒去调用一次var disConnect = function(){ ???setTimeout(function(){ ????????reconnect(); ???},5000);}//函数放在onclose里ws.onclose = disConnect;

 转自 https://www.uedbox.com/websocket-reconnect/

reconnecting-websocket.js

原文地址:https://www.cnblogs.com/anxiaoyu/p/9009817.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved