Vue3封装全局WebSocket;全局可监听、可发送、心跳处理等;

操作如下

可以在多个页面多个组件中进行监听/发送 代码简介 方便;

首先安装 tools-javascript 以及 tools-vue3

javascript 复制代码
npm i tools-vue3
npm i tools-javascript 
javascript 复制代码
import { WebSocketBean } from 'tools-vue3' 
export default class WSUtil {
    static ws: WebSocketBean
    static async init() { 
        this.ws = new WebSocketBean({
            url: '你的地址',
            needReconnect: true,
            reconnectGapTime: 3000,
            onerror: () => { // 接收到错误
                CEvent.emit('getData','断开的~消息是从这里来的哦~')
            }, 
            sendSuffix:'',
            messageSuffix: '',
            heartSend: '44444444444~',
            heartGet: '44444444444444444~',
            heartGapTime: 3000,
            onmessage: (data) => { // 接收到消息
                CEvent.emit('getData',sp)
            }
        })
        //建立连接
        this.ws.start()
    }
}

根据你的业务需求初始化 ws

javascript 复制代码
// 从你业务需求的文件引入该方法后调用
WSUtil.init()  

在你的任何文件中直接调用即可

javascript 复制代码
	// 监听消息 getData 相当于KEY值 与 接收到的消息/错误 统一即可
	const listenID = CEvent.on("getData",(data)=>{
		//在onmessage触发后,这里应该打印test字符串 
		console.log('home1',data)
	})
	// 页面销毁记得清除监听器
	onDeactivated(()=>{
        // 销毁
        CEvent.off(listenID)
	})

附加篇(也可不读 直接看文档 )

javascript 复制代码
 /**
  *发送数据
  * @param data 数据对象,Object、Array、String
  */
	WSUtil.send
	
 /**
  * 销毁需要重发的数据信息
  * @param sendId
  */
  WSUtil.offsend
 /**
  * 关闭socket,销毁绑定事件、心跳事件、窗口关闭事件,修改状态为已关闭
  */
  WSUtil.close
  
// ws连接状态
export enum WebSocketStatusEnum {
    /**
     * 创建中
     */
    load,
    /**
     * 已连接
     */
    open,
    /**
     * 已关闭
     */
    close
}
相关推荐
hong_zc40 分钟前
网络原理(四)—— 网络层、数据链路层 与 DNS
网络·dns·数据链路层·网络层
云计算DevOps-韩老师1 小时前
【网络云SRE运维开发】2025第3周-每日【2025/01/14】小测-【第13章ospf路由协议】理论和实操解析
网络·智能路由器·运维开发
打鱼又晒网1 小时前
linux网络 | https前置知识 | 数据加密与解密、数据摘要
网络·网络协议·https
路星辞*1 小时前
PBR(策略路由)的几种使用方式
运维·服务器·网络·安全·pbr
Cikiss1 小时前
HTTP详解——HTTP基础
网络·网络协议·计算机网络·http
武汉唯众智创2 小时前
计算机网络开发基础实训室设备
网络·计算机网络实训室·计算机网络开发基础实训室·计算机网络开发实训室·计算机网络开发
网安CILLE2 小时前
2025年——【寒假】自学黑客计划(网络安全)
linux·网络·python·安全·web安全·网络安全·ddos
癞皮狗不赖皮2 小时前
WEB 攻防-通用漏-XSS 跨站脚本攻击-反射型/存储型/DOM&BEEF-XSS
前端·网络·网络安全·xss
癞皮狗不赖皮3 小时前
WEB攻防-通用漏洞_XSS跨站_MXSS_UXSS_FlashXSS_PDFXSS
网络·安全·web安全·xss
路星辞*4 小时前
ssl与ipsec的区别
运维·网络·网络协议·ssl·ipsec