vue socket 封装配合store使用

该博客介绍了如何在Vue应用中使用WebSocket进行实时数据通信,并结合Vuex状态管理库管理接收到的数据。当WebSocket连接打开时,发送心跳并初始化数据绑定。当接收到服务器消息时,将数据存储到Vuex中。同时,当WebSocket连接关闭或出现错误时,实现重连机制。在组件中,可以通过Vuex获取和监听这些实时数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 socket封装配合store使用

import store from '@/store';
const WSS_URL = 'ws://访问地址’
let Socket = ''
let setIntervalWesocketPush = null

// 建立连接
export function createSocket() {
    if (!Socket) {
        console.log('建立websocket连接')
        Socket = new WebSocket(WSS_URL)
        Socket.onopen = onopenWS
        Socket.onmessage = onmessageWS
        Socket.onerror = onerrorWS
        Socket.onclose = oncloseWS
    } else {
        console.log('websocket已连接')
    }
}
// 打开WS之后发送心跳
function onopenWS() {
    console.log('监听打开')
    sendPing() //发送心跳
    // 初始绑定 根据需求来可删
    sendWSPush({
        type:'bind',
        category:''
    })
}
// 连接失败重连
function onerrorWS() {
    clearInterval(setIntervalWesocketPush)
    Socket.close()
    createSocket() //重连
}
// WS数据接收统一处理
export function onmessageWS(e) {
    // console.log('监听服务器发送的消息',e.data)
    // console.log(JSON.parse(e.data))
const data JSON.parse(e.data)
    //获取到的数据存在对应的store 数据里面
    if (data.code == '104005') {
        //调用store里面自定义修改数据的方法
        store.commit('setcoilCarcardData', data);
    }
}
export function sendWSPush(value) {
    // Socket.send(JSON.stringify(value));
    if (Socket !== null && Socket.readyState === 3) { //连接失败
        Socket.close()
        createSocket() //重连
    } else if (Socket.readyState === 1) {  //连接正常
        Socket.send(JSON.stringify(value));
    } else if (Socket.readyState === 0) {  //准备连接
        setTimeout(() => {
            Socket.send(JSON.stringify(value));
        }, 3000)
    }
}
/**关闭WS */
export function oncloseWS(e) {
    console.log('websocket 断开: ' + e.code + ' ' + e.reason + ' ' + e.wasClean)
    clearInterval(setIntervalWesocketPush)
    if(!e.wasClean){
        // Socket = ''
        createSocket()
    }
}
/**发送心跳 */
export function sendPing() {
    setIntervalWesocketPush = setInterval(() => {
        sendWSPush({ type: 'ping' });
    }, 5000)
}

export {Socket}

全局使用:

import {createSocket from '@/api/scoket.js'
//在app.vue created生命周期里面调用方法
async created(){

createSocket()
}

局部使用:

get coilCarcardData(){
return this.$store.state.coilCarcardData;
}
@Watch('coilCarcardData')
watchcoilCarcardData(res){
//获得到的数据自行做相应的处理
}

### 封装 WebSocket 实现 Vue.js 中的通信 #### 1. 初始化 WebSocket 并集成至项目 为了使 WebSocket 功能能够被整个应用访问,可以在项目的公共工具目录下创建 `ws.js` 文件用于封装 WebSocket 的基本操作。对于带有登录功能的应用程序而言,在主要页面如 `Home.vue` 组件内完成初始化工作是一个不错的选择。 ```javascript // @/utils/ws.js import { useWebSocketStore } from '@/stores/webSocket'; export function initWebSocket() { const store = useWebSocketStore(); store.connect('ws://your-websocket-url'); } ``` 在 Home.vue 或者其他合适的全局生命周期钩子中调用此函数可以确保当用户进入首页或者其他指定位置时自动建立 WebSocket 连接[^1]。 #### 2. 发送消息与接收响应处理 为了让各个组件都能轻松发送 WebSockets 请求以及监听服务器返回的数据,还需要定义一个通用的消息发送接口 `sendWebsocket()` 和相应的回调机制。这通常意味着要在目标组件内部注册事件处理器以便于捕获到来的信息: ```javascript // @/utils/ws.js 添加如下方法 export function sendWebsocket(callback) { const store = useWebSocketStore(); if (store.socket.readyState === WebSocket.OPEN) { // 假设这里实现了具体的发送逻辑... callback({ message: "模拟收到的消息" }); } } // 在需要使用的组件里像这样使用它: created () { sendWebsocket(this.onWebSocketMessage); }, methods: { onWebSocketMessage(data) { console.log(`Received data: ${data.message}`); } } ``` 通过这种方式,任何希望参与实时通讯的部分都可以简单地导入这两个辅助函数并按照需求执行相应动作。 #### 3. 处理异常情况下的重新连接 考虑到网络波动可能导致意外断开的情况,应该考虑加入重试机制以维持稳定的服务质量。利用状态管理库比如 Pinia 来保存当前连接的状态,并在其基础上构建一套完善的错误恢复流程显得尤为重要。 ```javascript // main.js 应用入口处配置 Store 及其行为 const webSocketStore = useWebSocketStore(); webSocketStore.connect('ws://localhost:8080'); if (!navigator.onLine || webSocketStore.status !== 'connected') { window.addEventListener('online', () => setTimeout(() => webSocketStore.reconnect(), 500)); } ``` 上述代码片段展示了如何检测离线状态并在恢复在线后尝试再次连接 WebSocket[^2]。 #### 错误报告 除了正常的交互外,还应当关注可能出现的问题并向开发者提供有用的反馈信息。例如设置专门针对 WebSocket 错误事件的侦听器可以帮助快速定位故障原因。 ```javascript // ws.js 内部增加错误捕捉部分 websock.onerror = function () { console.error('WebSocket connection error occurred.'); }; ``` 这样做不仅有助于调试期间发现问题所在,也能让用户界面更加友好地应对突发状况[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值