位置: 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 设置)

  • 华为freebudspro2怎么查找(华为freebudspro2怎么开降噪)

    华为freebudspro2怎么查找(华为freebudspro2怎么开降噪)

  • iqoo8pro支持wifi6吗(iqoo8pro支持多少w快充)

    iqoo8pro支持wifi6吗(iqoo8pro支持多少w快充)

  • realme gt neo2怎么设置红包助手(realme GT Neo2怎么读)

    realme gt neo2怎么设置红包助手(realme GT Neo2怎么读)

  • x70是曲面屏吗(vivox60曲屏版)

    x70是曲面屏吗(vivox60曲屏版)

  • 快手有消息为什么没有红点提示呢(快手有消息为什么不提醒)

    快手有消息为什么没有红点提示呢(快手有消息为什么不提醒)

  • 华为维修要不要发票

    华为维修要不要发票

  • 苹果x屏幕漏液能挺多久(iphone13屏幕漏液)

    苹果x屏幕漏液能挺多久(iphone13屏幕漏液)

  • 微信运动步数不动怎么设置(微信运动步数不准确解决办法)

    微信运动步数不动怎么设置(微信运动步数不准确解决办法)

  • 如何显示没有下划线的超链接(如何显示没有下划线的超链接正确答案是)

    如何显示没有下划线的超链接(如何显示没有下划线的超链接正确答案是)

  • 华为手机屏幕一部分失灵怎么办(华为手机屏幕一条竖线)

    华为手机屏幕一部分失灵怎么办(华为手机屏幕一条竖线)

  • 电子秤不归零怎么回事(电子秤 不归零)

    电子秤不归零怎么回事(电子秤 不归零)

  • ipad循环自动重启(ipad总是自动重启)

    ipad循环自动重启(ipad总是自动重启)

  • 苹果6老是自动重启怎么回事(苹果6老是自动关机怎么办)

    苹果6老是自动重启怎么回事(苹果6老是自动关机怎么办)

  • 进程和程序的本质区别(进程和程序的本质区别是)

    进程和程序的本质区别(进程和程序的本质区别是)

  • 华为nova3数据线多长(华为nova3数据线是什么接口)

    华为nova3数据线多长(华为nova3数据线是什么接口)

  • OPPO k5有红外线功能吗(oppo k5有红外线吗)

    OPPO k5有红外线功能吗(oppo k5有红外线吗)

  • win 10的运行在那(w10的运行在哪)

    win 10的运行在那(w10的运行在哪)

  • vivos1支不支持快充(vivos1手机快充怎么开启功能在哪里)

    vivos1支不支持快充(vivos1手机快充怎么开启功能在哪里)

  • 手机淘宝勋章怎么领(手机淘宝勋章金币在哪里领)

    手机淘宝勋章怎么领(手机淘宝勋章金币在哪里领)

  • word2019怎么生成二维码(word怎么生成docx文件)

    word2019怎么生成二维码(word怎么生成docx文件)

  • 通过微信名称能够查到微信号吗(通过微信名称能起诉对方吗)

    通过微信名称能够查到微信号吗(通过微信名称能起诉对方吗)

  • oppoa9x处理器是什么(oppoa9x手机处理器是什么)

    oppoa9x处理器是什么(oppoa9x手机处理器是什么)

  • xr有3d touch吗

    xr有3d touch吗

  • qq怎么恢复好友手机版本(QQ怎么恢复好友天数)

    qq怎么恢复好友手机版本(QQ怎么恢复好友天数)

  • 什么是kingroot(什么是kingdom)

    什么是kingroot(什么是kingdom)

  • 最强大的人工智能chatGPT不会还有人没用过吧,再不用就out了(最强大的人工智能武器)

    最强大的人工智能chatGPT不会还有人没用过吧,再不用就out了(最强大的人工智能武器)

  • 不含税买货合法吗
  • 土地税和房产税缴纳时间
  • 资源税的计税方法自产
  • 调整以前年度少计提的工资
  • 公司注销章要销毁吗
  • 借别人钱收据怎么写
  • 质量问题扣对方货款账务处理
  • 多计提以前年度损益调整账务处理怎么做
  • 残保金超比例奖励
  • 印花税按次申报和按期申报区别
  • 车辆一次性入费用会计分录
  • 金蝶K3如何设置套打
  • 物业公司收取水费如何开具发票
  • 年报填写中,认缴出资时间怎么填?
  • 工资薪金总额包括职工福利费吗
  • 股东划入资产会计处理
  • 库存成本与实际成本不符
  • 国家减免税额怎么入账
  • 全年累计应税所得额
  • 帮别的公司代销产品,对方公司不开具发票怎么做帐
  • netframework4.8安装未成功
  • 销售商品分期收款,减免一部分货款怎么做账
  • 【免费】多种方法手把手教你如何将自己做的网页做成网络链接(直接访问)
  • 为什么Windows 7搜不到网
  • u盘无内容
  • 台式电脑组装过程视频
  • 贷款利息不能抵扣进项税
  • PHP:highlight_string()的用法_misc函数
  • 上月抵扣的发票怎么开
  • ErrorCaptureStackTrace(err); Error [ERR_MODULE_NOT_FOUND]: Cannot find module
  • js日期字符串转换为指定格式的日期
  • RuntimeError: (PreconditionNotMet) The third-party dynamic library (cudnn64_7.dll) that Paddle depen
  • lsass.exe是什么进程
  • php教程 csdn
  • 其他债权投资按公允价值计量,为什么计提减值准备知乎
  • php封装app
  • 狮子岩斯里兰卡
  • 代扣代缴个人所得税手续费返还 增值税
  • 生产性生物资产折旧计入什么科目
  • framework core
  • ros urdf
  • 陶尔米纳电影节
  • php array操作
  • node实战
  • 蓝桥杯c题库及答案
  • 应收账款提了坏账后收回
  • python中有很多包管理工具
  • 退回社保怎么做分录
  • java一天速成
  • 差额增值税发票和全额增值税发票
  • 去年少计提费用
  • 铁路运费印花税谁承担
  • 确定施工程序怎么写
  • 产品质量监督检查的重点是
  • 固定资产大修理支出摊销年限
  • 组织员工旅游的租宿费的税额是什么
  • 电信发票为什么有单位
  • 本年利润的计算顺序为
  • 航空公司变更起飞时间赔偿
  • 银行存款日记账模板
  • 没有期初数据会怎么样
  • sql多表连接查询(详细实例)
  • vpengine.exe进程
  • Win10系统如何开启全部权限
  • linux用户权限管理
  • linux安装软件怎么安装
  • Win10 PC RS2快速预览版14926更新与修复内容汇总
  • 如何让电脑系统更快
  • win7为什么打不开原神
  • win8.1网络设置
  • 如何打开win7
  • extjs DataReader、JsonReader、XmlReader的构造方法
  • nodejs基础知识
  • 关于javascript中数组的说法不正确
  • python基础教程电子版
  • 设计模式的原则
  • js中!
  • python socket用法
  • 中山市地方税务局官网
  • 建筑装饰业发票怎么开
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设