news 2026/3/15 14:05:41

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/3/13 18:17:40

构建未来测试力场:自动化测试工程师三维技能图谱

自动化测试的时代定位 截至2025年末&#xff0c;随着云原生、AI工程化的深度渗透&#xff0c;软件测试领域正经历着从"辅助验证"到"质量驱动"的范式转移。自动化测试工程师不再仅仅是脚本编写者&#xff0c;而是成为保障数字产品质量的核心工程师。本文将…

作者头像 李华
网站建设 2026/3/14 1:08:59

JUnit4参数化测试动态生成:告别重复代码的智能测试方案

JUnit4参数化测试动态生成&#xff1a;告别重复代码的智能测试方案 【免费下载链接】junit4 A programmer-oriented testing framework for Java. 项目地址: https://gitcode.com/gh_mirrors/ju/junit4 你是否厌倦了在测试类中编写大量重复的测试方法&#xff1f;当业务…

作者头像 李华
网站建设 2026/3/15 8:34:00

测试人员的思维模式:从问题发现者到质量守护者的心智框架

在当今快速迭代的软件开发环境中&#xff0c;软件测试已不再是简单的“找bug”环节&#xff0c;而是确保产品高质量交付的核心支柱。截至2025年&#xff0c;随着人工智能、云计算和物联网技术的深度融合&#xff0c;软件系统变得日益复杂&#xff0c;测试人员面临着前所未有的挑…

作者头像 李华
网站建设 2026/3/13 8:19:35

测试中的认知偏差:如何识别与应对思维陷阱

在软件测试中&#xff0c;测试人员的思维模式往往直接影响测试结果的准确性和可靠性。认知偏差&#xff0c;作为一种普遍存在的心理现象&#xff0c;指人们在信息处理过程中无意识产生的系统性错误。对于软件测试从业者而言&#xff0c;这些偏差可能带来严重后果&#xff0c;例…

作者头像 李华
网站建设 2026/3/13 4:28:15

测试决策的心理因素:在认知偏差与专业判断间寻找平衡

当软件测试遇见心理学 在2025年的软件测试领域&#xff0c;技术工具的迭代速度令人惊叹&#xff0c;自动化测试覆盖率已成为行业基准&#xff0c;AI辅助测试工具也逐渐普及。然而&#xff0c;无论技术如何演进&#xff0c;测试决策的核心仍然离不开人类的判断——这一过程深受…

作者头像 李华