news 2026/4/3 1:25:54

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/20 4:41:14

构建专业体育直播系统:必备体育数据接入全指南(从基础到进阶)

构建专业体育直播系统&#xff1a;必备数据接入全指南&#xff08;从基础到进阶&#xff09;要打造功能完整、体验流畅的专业体育直播系统&#xff0c;数据是决定系统体验与专业度的核心驱动力。本文将系统梳理六大类必备数据模块&#xff0c;明确各模块核心字段与应用价值&…

作者头像 李华
网站建设 2026/4/2 12:59:40

超越工具迷恋:论自动化测试中可持续性的核心地位与实践路径

引言&#xff1a;超越工具&#xff0c;聚焦可持续性‌ 在当今快速迭代的软件开发环境中&#xff0c;自动化测试不再是“可有可无”的附属品&#xff0c;而是保障产品稳定性的关键支柱。据行业调查显示&#xff0c;超过70%的测试团队在实施自动化时面临失败&#xff0c;原因往往…

作者头像 李华
网站建设 2026/3/27 11:04:21

JD-GUI终极实战:Java代码逆向分析的10个高效技巧

JD-GUI终极实战&#xff1a;Java代码逆向分析的10个高效技巧 【免费下载链接】jd-gui A standalone Java Decompiler GUI 项目地址: https://gitcode.com/gh_mirrors/jd/jd-gui 在Java开发领域&#xff0c;掌握代码逆向分析能力是每个中级开发者必备的技能。JD-GUI作为业…

作者头像 李华
网站建设 2026/3/27 16:04:49

C语言字符串

文章目录 字符串基本概念定义和初始化字符串输入输出如下格式均可实现输入输出 字符串遍历操作字符串和字符指针字符指针的赋值引用 通用的字符串处理函数输入输出复制 连接 比较 求长度链接比较长度查找替换 字符串 基本概念 1.C语言字符串本质就是数组的延伸&#xff0c;以…

作者头像 李华
网站建设 2026/3/21 6:10:32

7大核心技术突破:WebRL-Llama-3.1-8B如何重塑智能浏览器交互新范式

你是否曾为重复性的网页操作感到疲惫&#xff1f;每天花数小时在不同网站间切换、点击、填写表单&#xff0c;却发现自己真正有价值的思考时间被严重挤压&#xff1f;在数字化信息爆炸的今天&#xff0c;传统浏览器操作模式已经成为制约工作效率的关键瓶颈。而WebRL-Llama-3.1-…

作者头像 李华