websocket重连

实现websocket重连很简单:只需要知道断网到浏览器约定时限等一些异常情况都会触发onclose和onerror,所以理论上,我们只要在onclose和onerror时,重新创建长连接就可以。

 

实现websocket重连的代码如下


var webSocketUrl = "ws://localhost:8899/tv/ws";

var ws = new WebSocket(webSocketUrl);

createWebSocket(webSocketUrl);

/**
 * 重连,webSocket连接未创建或者不是连接成功的状态,重新连接
 */

function reconnect(url) {
    setTimeout(function(){
        createWebSocket(url)
    },500);
}

/**
 * 实例websocket
 */

function createWebSocket(url) {
    try {
        if ('WebSocket' in window) {
            ws = new WebSocket(url);
        } else if ('MozWebSocket' in window) {
            ws = new MozWebSocket(url);
        } else {
            _alert("当前浏览器不支持websocket协议,建议使用现代浏览器",3000)
        }
        initWebSocket();
    }catch (e) {
        reconnect(url);
    }
}

/**
 * 初始化事件函数
 */

function initWebSocket () {
    ws.onopen = function (evt) {
        console.log("websocket连接成功");
    }

    ws.onmessage = function(evt) {
        console.log("websocket消息: ", JSON.parse(evt.data));
        //此处放渲染函数
    }
    ws.onclose = function () {
        reconnect(webSocketUrl);
    };
    ws.onerror = function (err) {
        reconnect(webSocketUrl);
    };
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值