位置: IT常识 - 正文

vue3+ts+Vuex中使用websocket协议方式(vuex 3)

编辑:rootadmin
这篇文章主要介绍了vue3+ts+Vuex中使用websocket协议方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教 目录

推荐整理分享vue3+ts+Vuex中使用websocket协议方式(vuex 3),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vuex 使用,vue vuex使用,vue3.0 使用vuex,vue3 + ts,vue3.0 使用vuex,vue +ts,vue +ts,vue3 + ts,内容如对您有帮助,希望把文章链接给更多的朋友!

vue3+ts+Vuex使用websocket协议在stroe中vue3中vue封装websocket封装的socket.js文件内容使用方法vue3+ts+Vuex使用websocket协议

本文作者使用的是ts+vue3的setup语法糖,大家注意使用的vue版本!

在stroe中import { createStore } from 'vuex'import { stateInt } from '../interface/storeInterface'const state: stateInt = {  //推送消息  data: {},  webSocket: null,}export default createStore({  state,  mutations: {    //websocket初始化    initWebsocket(state) {      state.webSocket = new WebSocket(          // 此处填写你要连接的ws地址        'ws://127.0.0.1:3000/socket/' + Math.random()      )      //建立连接      state.webSocket.onopen = function () {        /*         * 连接成功         * */        console.log('通讯开始')        // 发送心跳防止ws协议自动断联        setInterval(() => {          state.webSocket.send('1')        }, 1000 * 60)      }      //接收服务端消息      state.webSocket.onmessage = function (e) {        /*         * 收到消息时回调函数         * */        console.log('收到的数据:', e.data)        // 如果数据对象为字符串,可转换为对象格式        let data = JSON.parse(e.data)        state.data = e.data        console.log(data)      }      state.webSocket.onerror = function () {        /*         * 通讯异常         * */        console.log('通讯异常')      }      state.webSocket.close = function () {        /*         * 关闭连接时回调函数         * */        console.log('连接已断开')      }    },  },  actions: {  },  modules: {},})

/interface/storeInterface 文件下的interface接口

export interface stateInt {  data: Object  webSocket: WebSocket}vue3中

在App.vue中,语法糖格式下

<script lang="ts" setup>    import { onBeforeMount } from 'vue'    import { useStore } from 'vuex'    /**     * 仓库     */    const store = useStore()    //websocket初始化    const initSocket = () => {      store.commit('initWebsocket')    }        onBeforeMount(() => {      //console.log('2.组件挂载页面之前执行----onBeforeMount')      initSocket()    })</script>vue封装websocket

项目中需要使用websocke,这个是我自己修修改改好多次之后用得最顺手的一版,分享一下。

这个封装需要搭配vuex使用,因为收到的数据都保存在vuex中了,真的绝绝子好用,解决了我一大堆问题。

如果需要可以搭配上心跳、websocke重连。

话说,vuex的使用也有好多坑,在踩坑的路上狂奔,下次再写vuex的

封装的socket.js文件内容var websock = null;var global_callback = null;var serverPort = "80"; // webSocket连接端口var wsuri = "ws://" + window.location.hostname + ":" + serverPort;function createWebSocket(callback) {if (websock == null || typeof websock !== WebSocket) {initWebSocket(callback);}}function initWebSocket(callback) {global_callback = callback;// 初始化websocketwebsock = new WebSocket(wsuri);websock.onmessage = function (e) {websocketonmessage(e);};websock.onclose = function (e) {websocketclose(e);};websock.onopen = function () {websocketOpen();};// 连接发生错误的回调方法websock.onerror = function () {console.log("WebSocket连接发生错误");//createWebSocket();啊,发现这样写会创建多个连接,加延时也不行};}// 实际调用的方法function sendSock(agentData ) {if (websock.readyState === websock.OPEN) {// 若是ws开启状态websocketsend(agentData);} else if (websock.readyState === websock.CONNECTING) {// 若是 正在开启状态,则等待1s后重新调用setTimeout(function () {sendSock(agentData);}, 1000);} else {// 若未开启 ,则等待1s后重新调用setTimeout(function () {sendSock(agentData);}, 1000);}}function closeSock() {websock.close();}// 数据接收function websocketonmessage(msg) {// console.log("收到数据:"+JSON.parse(e.data));// console.log("收到数据:"+msg);// global_callback(JSON.parse(msg.data));// 收到信息为Blob类型时let result = null;// debuggerif (msg.data instanceof Blob) {const reader = new FileReader();reader.readAsText(msg.data, "UTF-8");reader.onload = (e) => {result = JSON.parse(reader.result);//console.log("websocket收到", result);global_callback(result);};} else {result = JSON.parse(msg.data);//console.log("websocket收到", result);global_callback(result);}}// 数据发送function websocketsend(agentData) {console.log("发送数据:" + agentData);websock.send(agentData);}// 关闭function websocketclose(e) {console.log("connection closed (" + e.code + ")");}function websocketOpen(e) {console.log("连接打开");}export { sendSock, createWebSocket, closeSock };

封装的websocke暴露三个接口

sendSock用于发送数据createWebSocket用于创建连接、对收到的数据进行处理closeSock 用于关闭连接使用方法

先看目录

vue3+ts+Vuex中使用websocket协议方式(vuex 3)

1、建立连接

建立好socket.js文件之后就可以开始使用了,因为我的登录是用axios的,只有登录成功(进入主页之后才建立websocke连接),所以我把连接写在了Home.vue的文件中。

第一步:导入文件

import { sendSock, createWebSocket, closeSock } from "@/api/socket";

第二步:初始化时建立websocket连接

created() {    this.init();    ......  },  methods: {    init() {      createWebSocket(this.global_callback);      ......    },     // websocket的回调函数,msg表示收到的消息    global_callback(msg) {      console.log("websocket的回调函数收到服务器信息:" + JSON.stringify(msg));      // console.log("收到服务器信息:" + msg);           switch (msg.operate) {//        case "autoIndex":          this.$store.dispatch("setAutoIndex", msg);          break;        case "allChannelSwitch":          this.$store.dispatch("setAllChannelSwitch", msg);          break;        case "singleChannelSwitch":          this.$store.dispatch("setSingleChannelSwitch", msg);          break;        case "sceneSelect":          this.$store.dispatch("setSceneSelect", msg);          break;          ......      }    },  },

msg.operate是用于判断收到通信数据

this.$store.dispatch()是用于异步修改vuex保存的数据的函数。

界面中通信数据收到后都保存在vuex中,需要该数据的地方就从vuex中获取

2、发送数据

第一步:导入文件

import { sendSock } from "@/api/socket";

第二步:发送数据

 var sendData = {        operate:"singleChannelSwitch",        index:index+1,        opera:row.button_relay      };      sendSock(JSON.stringify(sendData));

3、关闭连接

第一步:导入文件

import { closeSock} from "@/api/socket";

第二步:关闭连接

closeSock();

以上为个人经验,希望能给大家一个参考,也希望大家多多支持本站。

本文链接地址:https://www.jiuchutong.com/zhishi/310397.html 转载请保留说明!

上一篇:在Python中字典按值排序的实现方法(python字典按要求)

下一篇:让WordPress实现页面预加载 Instant.page使用教程(wordpress 设置)

  • 互联网+时代,医疗APP怎样有效推广?

    互联网+时代,医疗APP怎样有效推广?

  • arxiv是什么意思(arxiv是什么级别的论文)

    arxiv是什么意思(arxiv是什么级别的论文)

  • 苹果7p怎么关闭微信暗黑模式(苹果7p怎么关闭home键震动)

    苹果7p怎么关闭微信暗黑模式(苹果7p怎么关闭home键震动)

  • 苹果手机儿童模式在哪

    苹果手机儿童模式在哪

  • qq群上限是多少人(qq群数量有限制吗)

    qq群上限是多少人(qq群数量有限制吗)

  • qq音乐怎么下载(qq音乐怎么下载免费歌曲)

    qq音乐怎么下载(qq音乐怎么下载免费歌曲)

  • 朋友圈不是共同好友能看见评论吗

    朋友圈不是共同好友能看见评论吗

  • 笔记本电脑部分按键失灵(笔记本电脑部分软件显示模糊)

    笔记本电脑部分按键失灵(笔记本电脑部分软件显示模糊)

  • 超感光徕卡四摄是什么意思(超感光徕卡四摄未来影像)

    超感光徕卡四摄是什么意思(超感光徕卡四摄未来影像)

  • 电脑怎么打化学式小数字(电脑怎么打化学角标)

    电脑怎么打化学式小数字(电脑怎么打化学角标)

  • 苹果壁纸视角缩放是什么意思(苹果壁纸视角缩放开关有什么区别)

    苹果壁纸视角缩放是什么意思(苹果壁纸视角缩放开关有什么区别)

  • 苹果id都能查出什么(苹果id能查什么)

    苹果id都能查出什么(苹果id能查什么)

  • 华为怎么查激活日期(华为怎么查激活手机日期)

    华为怎么查激活日期(华为怎么查激活手机日期)

  • 华为askaloox是什么型号(华为型号ask-al00x是哪款)

    华为askaloox是什么型号(华为型号ask-al00x是哪款)

  • word手动目录怎么增加一行(word手动目录怎么设置)

    word手动目录怎么增加一行(word手动目录怎么设置)

  • 手机怎么进入安全模式(手机怎么进入安卓调试桥)

    手机怎么进入安全模式(手机怎么进入安卓调试桥)

  • 闹钟响了怎么关(闹钟响了怎么关(不是手机闹钟))

    闹钟响了怎么关(闹钟响了怎么关(不是手机闹钟))

  • 抖音账号注销后别人还能看到我吗(抖音账号注销后作品还在吗)

    抖音账号注销后别人还能看到我吗(抖音账号注销后作品还在吗)

  • vivoy97闪充功能在哪(vivoy97手机闪充模式怎么开启)

    vivoy97闪充功能在哪(vivoy97手机闪充模式怎么开启)

  • airpods连接成功没声音(airpods连接成功但是还是外放)

    airpods连接成功没声音(airpods连接成功但是还是外放)

  • 微信聊天页面右上角红点(微信聊天页面右上角显示顿号什么意思)

    微信聊天页面右上角红点(微信聊天页面右上角显示顿号什么意思)

  • qq防沉迷怎么解除(qq防沉迷系统怎么解)

    qq防沉迷怎么解除(qq防沉迷系统怎么解)

  • 苹果相册人物怎么增加(苹果相册人物怎么关闭,删了又有)

    苹果相册人物怎么增加(苹果相册人物怎么关闭,删了又有)

  • 小米9关闭指纹亮屏(小米关闭指纹解锁震动)

    小米9关闭指纹亮屏(小米关闭指纹解锁震动)

  • 【HTML】有趣的代码合集(附源码)(有趣的css代码)

    【HTML】有趣的代码合集(附源码)(有趣的css代码)

  • 劳务公司怎么交税,都有哪些税
  • 报税怎么操作流程图
  • 税金及附加属于营业成本吗
  • 出差人员个人原因延迟返回
  • 代开普通发票需提供哪些材料
  • 律师事务所的所训
  • 资产负债表库存为负数怎么调整
  • 科研材料怎么买
  • 税金及附加有啥
  • 城建税计税依据扣除增值税期末留抵
  • 退休工资怎样扣社保
  • 怎么分清复利和年金
  • 国税变更办税人怎么变更
  • 公司注册资本会留存多少
  • 增值税小规模纳税人的税率
  • 减税降费政策六税
  • 速达财务软件使用说明
  • 公司账上的存货是怎么来的
  • 公司注销必须要清算报告吗
  • 电子发票已缴税怎么查
  • 电信服务通信服务费计入什么科目
  • cpu调度schedutil好吗
  • php各大框架以及实现原理
  • 半成品月末账务处理
  • hue环境搭建
  • 帝国cms移动端
  • PHP:mcrypt_cfb()的用法_Mcrypt函数
  • vue组件继承并重写属性方法
  • 房地产企业营改增是哪一年
  • 一朵牛肝菌 (© vnosokin/Getty Images)
  • phpunit
  • 增值税已认证抵扣
  • 预付卡怎么开票
  • JavaScript数组(四):判断数组相等的4种方法
  • 深度学习之bottleneck layer
  • idea如何运行别人的vue项目
  • 收到对方退回的现金
  • 3d沙盒游戏推荐
  • 商业银行贷款的资本充足率
  • 企业所得税月月交吗
  • 无追保理是什么意思
  • 2022年最新版微信
  • phpcms添加内容
  • 土增清算后再销售
  • 一次还本付息债券定价公式
  • 公司注销未分配利润如何处理
  • 会计中的明细科目是什么
  • 企业所得税纳税申报表
  • 营改增土地出让金抵减销售额如何做账及申报纳税的...
  • 铁路运费印花税怎么算
  • 财务费用具体包括
  • 免税蔬菜交企业所得税吗
  • 未开票收入下月开票会计分录
  • 公司固定资产明细表
  • 水利建设基金缴纳增值税开始缴纳
  • 其他货币资金包含的内容
  • 互联网代记账业务
  • 计算机二级考试报名入口官网
  • CentOs7.x安装Mysql的详细教程
  • linux 新手
  • linux存在的意义
  • win7如何彻底关闭135端口 dcom
  • win10系统预览版
  • win10快速隐藏窗口
  • linux sed -s
  • win7卸载软件时显示program
  • windows视频截屏
  • android基础入门
  • android 开发 教程
  • border:none与border:0使用区别
  • vue miniui
  • vue只适合做单页项目吗