实时通信Socket io的使用示例详解
引言
最近在工作中,遇到了一个需求,需要和后台服务实时通信,获取各种设备的实时状态、以及对设备下发指令。后端这边选择了socket.io这个库,前端这边配合也只能使用这个,它的使用方式跟websocket很类似,为此简单记录一下socket.io的使用,希望帮助到有需要的人。
1、什么是socket.io
Socket.IO 是一个库,可以在客户端和服务器之间实现 低延迟, 双向 和 基于事件的 通信。
它建立在 WebSocket 协议之上,并提供额外的保证,例如回退到 HTTP 长轮询或自动重新连接。
2、socket.io的使用
1、安装引入
npm install socket.io-client import { io } from "socket.io-client";
2、初始化
const socket = io("https://server-domain.com");
3、使用
socket链接成功以后,我们继续接下来的操作,了解各个事件的使用。
socket.on("connect", () => { //监听连接是否成功 console.log("链接成功"); }); socket.on("disconnect", (reason) => { //监听连接异常中断 console.log("中断", reason); }); socket.on("message_event", (data) => { console.log("接收到的消息", data); }) // 此处需要注意的是on是一个监听事件,监听的message_event是和后台约定好的事件名。 前端主动断开链接 socket.close()或者 socket.disconnect()
4、消息的发送
// 发送消息 sendMessage(msgType, msgContent) { var jsonObject = { msgType: msgType, msgContent: msgContent }; socket.emit("send_event", jsonObject); }, //前端这边通过emit发送消息,这里的send_event也是跟后端人员约定好的事件。
3、客户端自带事件
除了上面介绍的几个主要事件外、还有一些其他事件
- connect:连接成功
- connecting:正在连接
- disconnect:断开连接
- connect_failed:连接失败
- error:错误发生,并且无法被其他事件类型所处理
- reconnect_failed:重连失败
- reconnect:成功重连
- reconnecting:正在重连
4、版本问题
socket.io分为客户端和服务器端,在选择使用的时候,一定要注意相关版本的选择要对应,要不然就会出现各种奇怪的问题,我当时做的时候没注意这一块,就耽误了一些时间。。。
相关版本兼容性如下表所示!
以上就是实时通信Socket io的使用示例详解的详细内容,更多关于Socket io实时通信的资料请关注脚本之家其它相关文章!
相关文章
Vue + Element 实现按钮指定间隔时间点击思路详解
这篇文章主要介绍了Vue + Element 实现按钮指定间隔时间点击,实现思路大概是通过加一个本地缓存的时间戳,通过时间戳计算指定时间内不能点击按钮,具体实现代码跟随小编一起看看吧2023-12-12vue中如何给el-table-column添加指定列的点击事件
elementui中提供了点击行处理事件,下面这篇文章主要给大家介绍了关于vue中如何给el-table-column添加指定列的点击事件,文中通过图文介绍的非常详细,需要的朋友可以参考下2022-11-11
最新评论