vue封装websocket以及心跳检测、重连

2024-04-18 18:37

本文主要是介绍vue封装websocket以及心跳检测、重连,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于websocket的封装有很多,此处记录一下自身项目已封装好的且已应用的,备份。

webSocketUtil.js:

class WebSocketUtils {constructor() {this.url = null //ws地址 或者 wssthis.data = nullthis.isOpenSocket = false //避免重复连接this.timeout = 20 //隔多久执行检测 单位秒(s)this.heartbeatInterval = null //检测服务器端是否还存活this.reconnectTimeOut = null //重连之后隔多久才再次重连}// 创建websocket连接connectSocketInit(url) {if (!this.socketTask || this.socketTask.readyState === WebSocket.CLOSED) {this.url = urlthis.socketTask = new WebSocket(url)this.socketTask.onopen = (event) => {console.log("==============WebSocket打开连接=============", event)clearTimeout(this.reconnectTimeOut)clearInterval(this.heartbeatInterval)this.isOpenSocket = truethis.socketTask.send(`ping`)this.startPingPong()}// 连接正常 接收消息中this.socketTask.onmessage = (event) => {console.log(event, '===========onmessage==============')try {if (event.data && event.data != 'null') {const jsonData = JSON.parse(event.data)console.log(jsonData, '===========onmessage=====jsonData=========')}} catch (err) {console.error('onmessage-err', err)}}//  socket关闭了会执行 此处this.socketTask.onclose = (event) => {console.log("========onclose============", event)this.isOpenSocket = falsethis.socketTask = nullthis.stopPingPong()if (event.code !== 4000) {setTimeout(() => {console.log('=========关闭重连reconnect===========')this.reconnect()}, 3000)}}this.socketTask.onerror = (error) => {console.log('============onerror============', error)}} else {console.log('Soeket exists, no need to create it, 链接状态:', this.socketTask.readyState === WebSocket.OPEN)}}//发送消息send(message) {//  连接正常打开时 ,才能正常成功发送消息if (this.socketTask && this.socketTask.readyState === WebSocket.OPEN) {this.socketTask.send(message)}}//重新连接reconnect() {const _this = thisif (!_this.url) {return}//停止发送心跳clearInterval(_this.heartbeatInterval)//如果不是人为关闭的话,进行重连if (!_this.isOpenSocket) {_this.reconnectTimeOut = setTimeout(() => {_this.connectSocketInit(_this.url)}, 3000)}}// 关闭 WebSocket 连接closeSocket(code = 4000, reason = '关闭') {const _this = this_this.socketTask.close(code,reason)_this.data = null_this.url = null_this.isOpenSocket = false// _this.socketTask = nullclearTimeout(_this.reconnectTimeOut)clearInterval(_this.heartbeatInterval)console.log('===============关闭 WebSocket 成功===================')}//开启心跳检测startPingPong() {const _this = thisif (_this.heartbeatInterval) {clearInterval(_this.heartbeatInterval);}_this.data = { value: "ping", name: "心跳检测" }_this.heartbeatInterval = setInterval(() => {// console.log('==========开启心跳检测====', _this.data)_this.send(JSON.stringify(_this.data))}, _this.timeout * 1000)}stopPingPong() {// 停止Ping-Pong定时器if (this.heartbeatInterval) {clearInterval(this.heartbeatInterval);this.heartbeatInterval = null;}}//将获的取消息导出外部exportMessage(callback) {this.socketTask.onmessage = (res) => {console.log(res, '===============exportMessage============')try {return callback(res.data)} catch (err) {console.error('exportMessage-err', err)return callback(err)}}}
}const websocketUtils = new WebSocketUtils()export default websocketUtils

引用:

再main.js中引入并挂载

import webSocketUtil from '@/utils/webSocketUtil';app.config.globalProperties.$webSocketUtil = webSocketUtil;

在所需页面打开连接,并监听数据返回

//监听消息
const handleWsMsg= (res) => {console.log('========handleWsMsg=========',res);
}proxy.$webSocketUtil.connectSocketInit('wss://xxxxxxxxx')
proxy.$webSocketUtil.exportMessage(handleWsMsg)//关闭连接
if(proxy.$webSocketUtil.socketTask){proxy.$webSocketUtil.closeSocket()
}

这篇关于vue封装websocket以及心跳检测、重连的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/915552

相关文章

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo