uniapp中使用WebSocket

在 uni-app 中,uni.connectSocket 方法用于建立 WebSocket 连接,但它并不提供 onOpenonMessageonCloseonError 这样的方法作为回调函数。相反,你应该使用 uni.onSocketOpenuni.onSocketMessageuni.onSocketCloseuni.onSocketError 这些全局事件来监听 WebSocket 的不同事件。

javascript 复制代码
<template>  
  <view>  
    <button @click="connectWebSocket">连接WebSocket</button>  
    <button @click="sendWebSocketMessage">发送消息</button>  
    <button @click="closeWebSocket">关闭WebSocket</button>  
  </view>  
</template>  
  
<script>  
export default {  
  data() {  
    return {  
      socket: null, // WebSocket实例  
      isConnected: false, // WebSocket连接状态  
    };  
  },  
  methods: {  
    // 连接WebSocket服务器  
    connectWebSocket() {  
      if (!this.isConnected) {  
        this.socket = uni.connectSocket({  
          url: 'ws://your-websocket-server-url' // 替换为你的WebSocket服务器URL  
        });  
  
        uni.onSocketOpen(res => {  
          console.log('WebSocket连接已打开!');  
          this.isConnected = true;  
        });  
  
        uni.onSocketMessage(res => {  
          console.log('收到WebSocket服务器消息:', res.data);  
        });  
  
        uni.onSocketClose(res => {  
          console.log('WebSocket连接已关闭!');  
          this.isConnected = false;  
        });  
  
        uni.onSocketError(err => {  
          console.error('WebSocket连接打开失败,请检查:', err);  
        });  
      }  
    },  
  
    // 发送WebSocket消息  
    sendWebSocketMessage() {  
      if (this.socket && this.isConnected) {  
        uni.sendSocketMessage({  
          data: '这是一条测试消息' // 发送的消息内容  
        });  
      } else {  
        console.error('WebSocket未连接或未打开,请先连接WebSocket!');  
      }  
    },  
  
    // 关闭WebSocket连接  
    closeWebSocket() {  
      if (this.socket) {  
        uni.closeSocket();  
        this.socket = null;  
        this.isConnected = false;  
      }  
    }  
  },  
  beforeDestroy() {  
    // 在组件销毁前,确保关闭 WebSocket 连接  
    this.closeWebSocket();  
  }  
};  
</script>

我使用了 uni.onSocketOpenuni.onSocketMessageuni.onSocketCloseuni.onSocketError 来监听 WebSocket 的事件。同时,在 sendWebSocketMessage 方法中,我添加了对 socket 实例和连接状态的检查,以确保在发送消息之前连接是打开的。最后,在 beforeDestroy 生命周期钩子中,我调用了 closeWebSocket 方法来确保在组件销毁时关闭 WebSocket 连接。

相关推荐
不知名的前端专家17 分钟前
UniApp USB存储设备U盘操作、读写原生插件
uni-app
coldriversnow1 小时前
uni-app从后端返回的富文本中的视频截取一帧为封面
uni-app
小吴-斌1 小时前
本地请求接口报SSL错误解决办法(Could not verify * SSL certificate)
网络·网络协议·ssl
2501_915918412 小时前
iOS 混淆与 IPA 加固一页式行动手册(多工具组合实战 源码成品运维闭环)
android·运维·ios·小程序·uni-app·iphone·webview
草莓熊Lotso2 小时前
基于容器适配器模式的 Stack 与 Queue 实现:复用底层容器的优雅设计
c++·网络协议·rpc·适配器模式
RollingPin5 小时前
iOS八股文之 网络
网络·网络协议·ios·https·udp·tcp·ios面试
Q_Q51100828516 小时前
python+uniapp基于微信小程序团购系统
spring boot·python·微信小程序·django·uni-app·node.js·php
炒毛豆16 小时前
uniapp微信小程序+vue3基础内容介绍~(含标签、组件生命周期、页面生命周期、条件编译(一码多用)、分包))
vue.js·微信小程序·uni-app
代码AI弗森17 小时前
无状态的智慧:从 HTTP 到大模型的系统进化论
网络·网络协议·http
酷熊代理17 小时前
安卓手机 IP 切换指南:告别卡顿,轻松换 IP
网络·网络协议·tcp/ip·socks5