webSocket Manager

WebSocket 连接管理器,用于统一管理多个 WebSocket 连接。这个管理器特别适用于需要同时维护多个 WebSocket 连接的复杂应用。
该连接管理器请配合,封装好的 uniapp websocket封装 使用。

js 复制代码
import WS from '@/utils/websocket.js'

class WebSocketManager {
  constructor() {
    this.connections = new Map()
  }

  /**
   * 建立或复用 WebSocket 连接
   * @param {string} url WebSocket 地址
   * @param {Function} onMessage 收到消息回调
   */
  connect(url, onMessage) {
    if (this.connections.has(url)) {
      console.log(`复用已有连接: ${url}`)
      return this.connections.get(url)
    }

    console.log(`新建连接: ${url}`)
    const ws = new WS({
      url,
      onConnected: () => {},
      onMessage: (data) => {
        if (onMessage) {
          onMessage(data)
        }
      },
    })

    this.connections.set(url, ws)

    // 自动清理无效连接
    const cleanup = () => {
      if (ws && ws.socketTask) {
        ws.socketTask.onClose(() => {
          console.log(`连接关闭,移除缓存: ${url}`)
          this.connections.delete(url)
        })
      }
    }

    setTimeout(cleanup, 0)

    return ws
  }

  /**
   * 发送消息
   * @param {string} url 目标地址
   * @param {any} message 消息内容
   */
  sendMessage(url, message) {
    const ws = this.connections.get(url)
    if (ws && ws.socketTask) {
      ws.socketTask.send({
        data: JSON.stringify(message),
        fail: (err) => {
          console.error('发送消息失败:', err)
        },
      })
    } else {
      console.warn(`未找到可用连接: ${url}`)
    }
  }

  /**
   * 主动关闭某个连接
   * @param {string} url 地址
   */
  close(url) {
    const ws = this.connections.get(url)
    if (ws) {
      ws.close()
      this.connections.delete(url)
    }
  }

  /**
   * 关闭所有连接(如页面卸载时)
   */
  closeAll() {
    for (const [url, ws] of this.connections.entries()) {
      ws.close()
    }
    this.connections.clear();
    console.log('所有websocket已关闭!')
  }
}

// 导出单例
const wsManager = new WebSocketManager()
export default wsManager

使用

从utils 里面引用连接管理器: import wsManager from '@/utils/webSocketManager.js'

js 复制代码
      let wsUrl = `${wsUrl}/websocket/handheld/ws/notify/${deviceCode}`; // ws地址
      
      // 连接 ws
      wsManager.connect(wsUrl, (data) => {
        console.log('*******ws消息:',data);
      })
js 复制代码
  onUnload() {
    // 关闭所有ws链接
    wsManager.closeAll()
  }
相关推荐
sorryhc几秒前
【AI解读源码系列】ant design mobile——Image图片
前端·javascript·react.js
老猴_stephanie几秒前
Sentry On-Premise 21.7 问题排查与处理总结
前端
sorryhc29 分钟前
【AI解读源码系列】ant design mobile——Button按钮
前端·javascript·react.js
VOLUN31 分钟前
PageLayout布局组件封装技巧
前端·javascript·vue.js
掘金安东尼31 分钟前
React 的 use() API 或将取代 useContext
前端·javascript·react.js
牛马喜喜31 分钟前
记录一次el-table+sortablejs的拖拽bug
前端
一枚前端小能手36 分钟前
⚡ Vite开发体验还能更爽?这些配置你试过吗
前端·vite
anyup1 小时前
🔥 🔥 为什么我建议你使用 uView Pro 来开发 uni-app 项目?
前端·vue.js·uni-app
Skelanimals1 小时前
Elpis全栈框架开发总结
前端
蓝胖子的小叮当1 小时前
JavaScript基础(十三)函数柯里化curry
前端·javascript