IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> websocket实时推送及重连机制 -> 正文阅读

[网络协议]websocket实时推送及重连机制

import { Notification } from 'element-ui'
const soket = {
  url: 'ws://xxxxxxxxxxxxxxxxxxxxxxx',
  ws: null,
  lockReconnect: true,

  // 实例websocket
  websocketFunc() {
    try {
      if ('WebSocket' in window) {
        this.ws = new WebSocket(this.url)
      } else {
        alert('当前浏览器不支持websocket协议', 3000)
      }
      this.initEventHandle()
    } catch (e) {
      this.reconnect()
    }
  },

  // 初始化事件函数
  initEventHandle() {
    this.ws.onclose = function() {
      console.log('报警推送关闭链接')
      if (soket.lockReconnect) {
        soket.reconnect()
      }
    }
    this.ws.onerror = function() {
      soket.reconnect()
    }
    // 连接成功建立的回调方法
    this.ws.onopen = function() {
      console.log('消息推送链接成功')
    }
    // 接收到消息的回调方法
    this.ws.onmessage = function(event) {
      var res = JSON.parse(event.data)
      console.log(res)
      Notification({
        type: 'success',
        title: '消息提醒',
        message: res.message,
        position: 'top-right',
        duration: 0
      })
    }
    // 监听窗口关闭事件,当窗口关闭时,主动去关闭websocket连接,防止连接还没断开就关闭窗口,server端会抛异常。
    window.onbeforeunload = function() {
      soket.lockReconnect = false
      this.ws.close()
    }
  },
  
  // 关闭连接
  closeWebSocket() {
    soket.lockReconnect = false
    this.ws.close()
    console.log('websocket已关闭!')
  },
  
  // 重连
  reconnect() {
    setTimeout(function() { // 没连接上会一直重连,设置延迟避免请求过多
      console.log('尝试重连...' + new Date())
      soket.websocketFunc()
    }, 2000)
  }
  
}
export default soket

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-03-03 16:49:22  更:2022-03-03 16:51:32 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 8:49:29-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码