广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >实时通信Socket io的使用示例详解
  • 958
分享到

实时通信Socket io的使用示例详解

Socket io实时通信Socket io 2022-11-16 00:11:00 958人浏览 安东尼
摘要

目录引言1、什么是Socket.io2、socket.io的使用3、客户端自带事件4、版本问题引言 最近在工作中,遇到了一个需求,需要和后台服务实时通信,获取各种设备的实时状态、以及

引言

最近在工作中,遇到了一个需求,需要和后台服务实时通信,获取各种设备的实时状态、以及对设备下发指令。后端这边选择了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实时通信的资料请关注编程网其它相关文章!

--结束END--

本文标题: 实时通信Socket io的使用示例详解

本文链接: https://www.lsjlt.com/news/172942.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作