Websocket使用方案详解(uniapp版)

主要目的:创建socket类,导出socket实例,引入使用。

一 初始化变量

SocketUrl 基础路由(根据开发和生产不同环境配置的变量)

SockStart 记录是否已发出请求,防止请求多次发送

二 初始化操作

2.1 打开socket错误监听

javascript 复制代码
uni.onSocketError(function (res) {
this.socketStart = false
console.log('WebSocket连接打开失败,请检查!')
})

2.2 WebSocket关闭监听

javascript 复制代码
    uni.onSocketClose((res) => {
      console.log('WebSocket 已关闭!')
      this.socketStart = false
      setTimeout(() => {
        this.init(this.socketType)
      }, 3000)
    })

三 接收消息

javascript 复制代码
uni.onSocketMessage((res) => {
  console.log('APP:--》收到服务器内容:')
  let data = JSON.parse(res.data)
  // console.log('收到服务器内容:', data);
  this.acceptMessage && this.acceptMessage(data)
})

可以看到消息监听中调用了acceptNessage方法,后续通过给改方法赋值就可以在获取到消息时执行对应的函数。

四 其他方法

类中主要的方法除了上面提到的错误监听、关闭监听、接收消息以外,还需要init启动函数,send发送消息函数(如果是做消息接收这种非互动的功能就不需要了),和关闭socket的函数(在用户退出或其他情况时调用)。

init函数中首先判断socket是否已启动(使用socketStart变量),已启动就退出方法,不做操作。否则使用对应url发出请求,注意socket的链接以wss或ws开头,

javascript 复制代码
.replace('https://', 'wss://').replace('http://', 'ws://') 

然后启用webSocket,使用uni.connectSocket方法即可。

javascript 复制代码
  uni.connectSocket({
      url: url,
      method: 'GET',
      protocols: [token],
    })

然后监听socket函数,确认打开后将socketStart置为true.

javascript 复制代码
```javascript
uni.onSocketOpen((res) => {
  this.socketStart = true
  callback && callback()
  console.log('WebSocket连接已打开!')
})

关闭socket方法比较简单,调用api即可,别忘了改变socketStart的值。

javascript 复制代码
closeSocket() {
    uni.closeSocket()
    this.socketStart = false
  }

五 最终

以上,一个基于uniapp的包括socket启动、接受消息、关闭、错误监听等基础功能的socket使用类就做好了。让我们试着用它吧。

javascript 复制代码
import socket from '@/common/socket'
socket.init('websocket')
socket.acceptMessage = function (res) {...}

取到消息后我们可以给uniapp的tabbar上设置角标。

javascript 复制代码
uni.setTabBarBadge({
  index: 1,
  text: msgCount2.value.length + '',
})

在进行查看动作后取消角标。

javascript 复制代码
  uni.removeTabBarBadge({
    index: 1,
  })
相关推荐
HashTang14 小时前
【AI 编程实战】第 12 篇:从 0 到 1 的回顾 - 项目总结与 AI 协作心得
前端·uni-app·ai编程
JunjunZ16 小时前
uniapp 文件预览:从文件流到多格式预览的完整实现
前端·uni-app
郑州光合科技余经理1 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
gihigo19981 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
TT_Close1 天前
“啪啪啪”三下键盘,极速拉起你的 uni-app 项目!
vue.js·uni-app·前端工程化
特立独行的猫a2 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS影视票房榜组件完整实现过程
华为·uni-app·harmonyos·轮播图·uniapp-x
白太岁2 天前
通信:(5) 电路交换、报文交换与分组交换
运维·服务器·网络·网络协议
小扎仙森2 天前
关于阿里云实时语音翻译-Gummy推送WebSocket
websocket·阿里云·云计算
00后整顿职场2 天前
Hbuilderx APP真机无法识别iqoo Z9+手机设备解决方案
uni-app·uniapp真机调试·真机运行
EasyGBS2 天前
国标安全升级:GB28181平台EasyGBS支持GB35114协议的应用场景与核心优势
网络协议·安全·gb28181·gb35114