在vue3中封装WebSocket

下载websocket

npm install websocket
或
yarn add websocket

一、新建webSockte.js文件

// webSocket.js  
// 自定义组合式函数,用于管理 WebSocket 连接  import { ref, onMounted, onBeforeUnmount } from "vue";  const useWebSocket = (url, reconnectInterval = 10000, maxReconnectAttempts = 5) => {  // 创建一个响应式引用来存储 WebSocket 实例  const socket = ref(null);  // 标记组件是否已挂载  const isMounted = ref(true);  // 标记 WebSocket 是否已连接  const isConnected = ref(false);  // 记录重连尝试次数  let reconnectAttempts = 0;  // 连接 WebSocket 的函数  const connect = () => {  // 如果已存在 WebSocket 实例,则先关闭它  if (socket.value) {  socket.value.close();  }  // 创建新的 WebSocket 实例  socket.value = new WebSocket(url);  // 监听 WebSocket 打开事件  socket.value.addEventListener("open", () => {  console.log("WebSocket连接已打开");  isConnected.value = true; // 更新连接状态  });  // 监听 WebSocket 消息事件  socket.value.addEventListener("message", (event) => {  console.log("收到消息:", event.data); messages.value = JSON.parse(event.data); });  // 监听 WebSocket 关闭事件  socket.value.addEventListener("close", () => {  console.log("WebSocket连接已关闭");  isConnected.value = false; // 更新连接状态  // 如果组件仍挂载且未达到最大重连尝试次数,则尝试重新连接  if (isMounted.value && reconnectAttempts < maxReconnectAttempts) {  // 使用递增的延迟来避免频繁重连  setTimeout(connect, reconnectInterval * (reconnectAttempts + 1));  reconnectAttempts++; // 增加重连尝试次数  }  });  // 监听 WebSocket 错误事件  socket.value.addEventListener("error", (error) => {  console.error("WebSocket发生错误:", error);  // 如果组件仍挂载,并且希望处理错误后重连,可以在这里添加逻辑  });  };  // 发送消息到 WebSocket  const sendMessage = (message) => {  if (socket.value && socket.value.readyState === WebSocket.OPEN) {  socket.value.send(message);  }  };  // 组件挂载时执行  onMounted(() => {  isMounted.value = true;  connect(); // 尝试建立连接  });  // 组件卸载前执行  onBeforeUnmount(() => {  isMounted.value = false;  if (socket.value) {  socket.value.close(); // 关闭 WebSocket 连接  }  });   // 返回对象,包含 WebSocket 实例、连接状态和发送消息的函数  return {  socket,  messages,isConnected,  sendMessage,  };  
};  export default webSocket;

二、页面中使用webSocket

<script setup>
import { onMounted, ref } from "vue";import webSocket from "./webSocket.js"; // 引入新建的webSocket.js文件
const { sendMessage, messages } = webSocket('ws://your-websocket-url', 10000, 5); // 监听 messages 的变化
watchEffect(() => {if (messages.value) {// 打印websocket传的值console.log(messages.value);}
});onMounted(() => {sendMessage("Hello WebSocket!");
});</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/878206.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【日常记录-Linux】unzip指令

Author&#xff1a;赵志乾 Date&#xff1a;2024-08-28 Declaration&#xff1a;All Right Reserved&#xff01;&#xff01;&#xff01; 1. 简介 unzip是一个在类Unix系统(如Linux、macOS)上广泛使用的命令行工具&#xff0c;用于解压缩.zip格式的文件。.zip是一种广泛支持…

离线环境玩转 Tauri

离线环境玩转 Tauri 1. Tauri 是什么 Tauri 是一个用于构建跨平台桌面应用程序的框架&#xff0c;它允许开发者使用前端技术&#xff08;如 React、Vue、Svelte 等&#xff09;来构建桌面应用程序&#xff0c;同时提供高性能和低资源消耗的特性。 Tauri 的核心思想是使用前端…

令牌和签名详细介绍+开发使用教程

令牌和签名简介 1. 令牌&#xff08;Token&#xff09; 概念 令牌&#xff08;Token&#xff09;是一个用于身份验证的小段数据&#xff0c;通常在用户登录时由服务器生成&#xff0c;并返回给客户端。客户端在后续的请求中将令牌附加到请求头中&#xff0c;服务器通过验证令…

鸿蒙 装饰器 @State、@Prop、@Link 等说明

首先要明白什么是“状态变量”?即被状态装饰器(@State、@Prop、@Link、@Provide、@Consume)修饰的变量,比如 @State str : string=; str就是状态变量。状态变量值的改变会引起UI界面重新渲染。 @State @State装饰的变量,是私有的,只能被组件内部访问,在声明时必须指定…

计算机视觉编程 1(图片处理)

目录 灰色度 缩略图 拷贝粘贴区域 调整图像尺寸 旋转图像45 画图线、描点 灰色度 灰度是指图像中每个像素的亮度值&#xff0c;用来描述图像中各个像素的明暗程度。在计算机视觉中&#xff0c;灰度可以通过以下方式来计算&#xff1a; 1. 平均值法&#xff1a;将图像中每…

【Linux】深入探讨Linux进程等待:`waitpid`与`wait`

文章目录 深入探讨Linux进程等待&#xff1a;waitpid与wait API一、waitpid与wait简介1. wait2. waitpid 二、waitpid与wait的实际应用1. 基本用法示例2. 使用 waitpid 处理多个子进程3. 非阻塞等待 三、使用场景 深入探讨Linux进程等待&#xff1a;waitpid与wait API 在Linux…

Java基础——自学习使用(泛型)

一、泛型的定义 泛型的本质是参数化类型&#xff0c;也就是所操作的数据类型被指定为一个参数。 泛型泛指一切类型&#xff0c;能够代表一切类型&#xff0c;是一种在编程中广泛使用的概念&#xff0c;特别是在面向对象编程中。它允许在编写代码时使用类型参数&#xff0c;这些…

WPS Office两个严重漏洞曝光,已被武器化且在野利用

WPS Office作为一款用户基数超过2亿的广泛使用的办公套件&#xff0c;被发现存在两个关键漏洞&#xff08;CVE-2024-7262和CVE-2024-7263&#xff09;&#xff0c;这些漏洞可能导致用户遭受远程代码执行攻击。这两个漏洞的CVSS评分为9.3&#xff0c;表明它们的严重性很高&#…

C++:Opencv读取ONNX模型,通俗易懂

1. 准备 ONNX 模型 假设你已经有一个训练好的 ONNX 模型文件。可以从各类深度学习框架&#xff08;如 PyTorch、TensorFlow&#xff09;中导出 ONNX 模型。例如&#xff0c;下面是一个简单的 PyTorch 模型导出为 ONNX 文件的示例&#xff1a; import torch import torchvisio…

在使用React Hooks中,如何避免状态更新时的性能问题?

在React Hooks中避免状态更新时的性能问题&#xff0c;可以采取以下一些最佳实践&#xff1a; 避免不必要的状态更新&#xff1a; 使用React.memo、useMemo、和useCallback来避免组件或其子组件进行不必要的渲染。 使用useMemo&#xff1a; 对于基于状态或props的复杂计算&…

MES管理系统助力印刷企业实现智能化工艺流程

在印刷这一古老而充满活力的行业中&#xff0c;科技的浪潮正以前所未有的速度重塑着每一个生产环节。随着制造业数字化转型的深入&#xff0c;引入MES管理系统&#xff0c;为印刷企业带来了从原材料入库到成品出库的全流程智能化变革&#xff0c;不仅提升了生产效率&#xff0c…

剪辑小白必看:好用的剪辑工具推荐!

作为一位热爱创作的视频制作者&#xff0c;我尝试过不少剪辑软件&#xff0c;今天我想分享自己对福昕视频剪辑、爱拍剪辑、达芬奇和VSDC Video Editor这四款软件的使用体验。 福昕视频剪辑 链接&#xff1a;www.pdf365.cn/foxit-clip/ 我第一次接触到福昕视频剪辑是在朋友的…

python基础语法2

python基础语法2 了解整体内容可以从基础语法1开始&#xff0c;第2天了&#xff0c;开始上代码片段。 本篇主要内容&#xff1a;控制流语句if、for、match等。 打印及main方法 # 注释使用#号 #打印hello def print_hello(name):#这里加上f是打印变量内容&#xff0c;不加f打印…

树数据结构(Tree Data Structures)的全面指南:深度解析、算法实战与应用案例

树数据结构&#xff08;Tree Data Structures&#xff09;的全面指南&#xff1a;深度解析、算法实战与应用案例 引言 树数据结构&#xff08;Tree Data Structures&#xff09;作为计算机科学中的基石之一&#xff0c;以其独特的层次结构和分支特性&#xff0c;在众多领域发…

2012-2022年各省新质生产力匹配数字经济数据

2012-2022年各省新质生产力匹配数字经济数据 1、时间&#xff1a;2012-2022年 2、来源&#xff1a;各省年鉴、能源年鉴、工业年鉴、统计年鉴 3、指标&#xff1a;prov、year、gdp亿元、在岗职工工资元、第三产业就业比重、人均受教育平均年限、教育经费强度、在校学生结构、…

【STM32】IWDG独立看门狗与WWDG窗口看门狗

本篇博客重点在于标准库函数的理解与使用&#xff0c;搭建一个框架便于快速开发 目录 WDG简介 IWDG IWDG特性 独立看门狗时钟 键寄存器 超时时间 IWDG代码 WWDG WWDG特性 窗口看门狗时钟 超时时间 WWDG时序 WWDG代码 IWDG和WWDG对比 WDG简介 WDG&#xff08;…

面经:什么是Transformer位置编码?

过去的几年里&#xff0c;Transformer大放异彩&#xff0c;在各个领域疯狂上分。它究竟是做什么&#xff0c;面试常考的Transformer位置编码暗藏什么玄机&#xff1f;本文一次性讲解清楚。 Transformer的结构如下&#xff1a; 可能是NLP界出镜率最高的图 Transformer结构中&a…

最大公约数(欧几里得算法)

欧几里得算法 只需要记住一个公式&#xff08;不需要推导&#xff0c;这就是数论的基础知识&#xff09;&#xff1a; step1&#xff1a; 判断小括号内右边的数字 b 是否为0&#xff0c;如果为0&#xff0c;输出小括号左边的数字 a &#xff0c;就是一开始要求的两个数的最大…

深度学习入门笔记

深度学习入门笔记 感知机逻辑与门与非门或门多层感知机异或门 神经网络激活函数输出层设计损失函数均方误差 MSE交叉熵误差 反向传播算法计算图局部计算计算图反向传播反向传播 参数更新训练过程总结 该篇文章为本人学习笔记的一部分。笔记基于《深度学习入门 基于python理论实…

49-结构化程序设计方法的理解

‌结构化程序设计方法‌是一种以提高程序可读性、易维护性、可调性和可扩充性为目标的程序设计方法。它基于模块化设计原则&#xff0c;将程序划分为多个功能模块&#xff0c;每个模块负责实现特定的功能。这种方法强调使用三种基本控制结构&#xff1a;顺序、选择和循环&#…