news 2026/5/1 7:24:38

websocket功能开发

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
websocket功能开发

websocket.js

/** * @module initWebSocket 初始化 * @module websocketonopen 连接成功 * @module websocketonerror 连接失败 * @module websocketclose 断开连接 * @module resetHeart 重置心跳 * @module sendSocketHeart 心跳发送 * @module reconnect 重连 * @module sendMsg 发送数据 * @module websocketonmessage 接收数据 * @module test 测试收到消息传递 * @description socket 通信 * @param {any} url socket地址 * @param {any} websocket websocket 实例 * @param {any} heartTime 心跳定时器实例 * @param {number} socketHeart 心跳次数 * @param {number} HeartTimeOut 心跳超时时间 * @param {number} socketError 错误次数 */ let socketUrl = ""; // socket地址 let websocket = null; // websocket 实例 let heartTime = null; // 心跳定时器实例 let socketHeart = 0; // 心跳次数 const HeartTimeOut = 10000; // 心跳超时时间 10000 = 10s let socketError = 0; // 错误次数 // 初始化socket export const initWebSocket = (url) => { socketUrl = url; // 初始化 websocket websocket = new WebSocket(url); websocketonopen(); websocketonmessage(); websocketonerror(); websocketclose(); sendSocketHeart(); return websocket; }; // socket 连接成功 export const websocketonopen = () => { websocket.onopen = function () { console.log("连接 websocket 成功"); resetHeart(); }; }; // socket 连接失败 export const websocketonerror = () => { websocket.onerror = function (e) { console.log("连接 websocket 失败", e); }; }; // socket 断开链接 export const websocketclose = () => { websocket.onclose = function (e) { console.log("断开连接", e); }; }; // socket 重置心跳 export const resetHeart = () => { socketHeart = 0; socketError = 0; clearInterval(heartTime); sendSocketHeart(); }; // socket心跳发送 export const sendSocketHeart = () => { heartTime = setInterval(() => { // 如果连接正常则发送心跳 if (websocket.readyState == 1) { // if (socketHeart <= 30) { websocket.send("ping"); socketHeart = socketHeart + 1; } else { // 重连 reconnect(); } }, HeartTimeOut); }; // socket重连 export const reconnect = () => { if (socketError <= 2) { clearInterval(heartTime); initWebSocket(socketUrl); socketError = socketError + 1; console.log("socket重连", socketError); } else { console.log("重试次数已用完"); clearInterval(heartTime); } }; // socket 发送数据 export const sendMsg = (data) => { websocket.send(data); }; // socket 接收数据 export const websocketonmessage = () => { websocket.onmessage = function (e) { if (e.data.indexOf("heartbeat") > 0) { resetHeart(); } if (e.data.indexOf("pong") != -1) { return; } let data = JSON.parse(e?.data); dispatchCustomEvent('onmessageWS',data) }; }; // 创建一个用于触发自定义事件的函数 function dispatchCustomEvent(eventName, data) { const event = new CustomEvent(eventName, { detail: data }); window.dispatchEvent(event); }

引入websocket.js

import { initWebSocket, websocketclose } from '@/utils/websocket' created() { this.initPageSocket() // websocket方式 }, mounted() { window.addEventListener('onmessageWS', this.getSocketData) // 监听websocket自定义消息获取 setTimeout(() => { this.initPageSocket() }, 1000) }, methods: { /** 初始化Socket - 获取数据 */ initPageSocket() { let userId = this.$store.state.user.userId let protocol = window.location.protocol === 'https:' ? 'wss://' : 'ws://' let scoketUrl = `${protocol}${process.env.VUE_APP_WEBSOCKET_URL}/ymws?userId=${userId}` this.socket = initWebSocket(scoketUrl) }, // 获取报警-长连接推送 getSocketData(res) { let result = res.detail this.tableData.unshift(result) // if (this.alarmLists.length >= 5) { // let arr = this.alarmLists.slice(1, 5) // arr.unshift(result) // this.$set(this, 'alarmLists', arr) // } else { // this.alarmLists.unshift(result) // } }, } destroyed() { if (this.socket) websocketclose() window.removeEventListener('onmessageWS', this.getSocketData) }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 5:02:20

雷达回波图光流法外推项目实战!

雷达回波图光流法外推 基于OpenCV实现的雷达回波图光流法外推工具&#xff0c;支持三种光流算法&#xff0c;包含完整的评估体系。 功能特性 支持三种光流算法&#xff1a;Farneback、Lucas-Kanade、DIS自动图像预处理和灰度转换多步外推预测命令行和API两种调用方式完整的评估…

作者头像 李华
网站建设 2026/5/1 5:01:38

打破心墙,智创未来:测试工程师的创新觉醒之路

当测试遇上创新&#xff0c;为何我们举步维艰&#xff1f; 在软件测试领域&#xff0c;测试工程师们日复一日地执行用例、报告缺陷&#xff0c;却在面对自动化、AI测试或敏捷转型时心生畏惧。这并非能力不足&#xff0c;而是深藏于心的心理障碍在作祟。本文聚焦软件测试从业者…

作者头像 李华
网站建设 2026/5/1 7:11:24

代码绘图革命:Drawnix如何用Mermaid语法重构你的流程图工作流

代码绘图革命&#xff1a;Drawnix如何用Mermaid语法重构你的流程图工作流 【免费下载链接】drawnix 开源白板工具&#xff08;SaaS&#xff09;&#xff0c;一体化白板&#xff0c;包含思维导图、流程图、自由画等。All in one open-source whiteboard tool with mind, flowcha…

作者头像 李华
网站建设 2026/5/1 5:02:32

数据结构:并查集

数据结构&#xff1a;并查集 并查集&#xff08;Disjoint Set Union&#xff0c;简称 DSU&#xff09;是一种用于高效管理和合并不相交集合的数据结构&#xff0c;核心支持两种操作&#xff1a; 查找&#xff08;Find&#xff09;&#xff1a;确定某个元素属于哪个集合&#xf…

作者头像 李华
网站建设 2026/5/1 6:11:14

5分钟搞定视频字幕:OpenSubtitlesDownload新手完整指南

5分钟搞定视频字幕&#xff1a;OpenSubtitlesDownload新手完整指南 【免费下载链接】OpenSubtitlesDownload Automatically find and download the right subtitles for your favorite videos! 项目地址: https://gitcode.com/gh_mirrors/op/OpenSubtitlesDownload 还在…

作者头像 李华