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

  • 目前进行微博营销过程存在哪些问题?(微博营销以什么作为营销平台,每一个什么都是)

    目前进行微博营销过程存在哪些问题?(微博营销以什么作为营销平台,每一个什么都是)

  • 影子系统对电脑造成的影响(影子系统对电脑有影响吗)

    影子系统对电脑造成的影响(影子系统对电脑有影响吗)

  • 苹果设备合法性检测能安装吗(苹果设备合法性检测怎么安装)

    苹果设备合法性检测能安装吗(苹果设备合法性检测怎么安装)

  • 苹果6s plus手机特别烫的原因(苹果6s plus手机壁纸)

    苹果6s plus手机特别烫的原因(苹果6s plus手机壁纸)

  • qq上的小船怎么才能灭(qq上的小船怎么弄的)

    qq上的小船怎么才能灭(qq上的小船怎么弄的)

  • 怎样查微信是否有分身(怎样查微信是否被登录过)

    怎样查微信是否有分身(怎样查微信是否被登录过)

  • excel电子表格能做什么(excel表格可以直接打印吗)

    excel电子表格能做什么(excel表格可以直接打印吗)

  • 华为hms有什么用(华为的hms是什么意思)

    华为hms有什么用(华为的hms是什么意思)

  • 苹果几是双卡双待(苹果几是双卡双待5G)

    苹果几是双卡双待(苹果几是双卡双待5G)

  • 拒收信息是拉黑了吗(对方拉黑信息能收到吗)

    拒收信息是拉黑了吗(对方拉黑信息能收到吗)

  • 打电话可以注销手机卡吗(打电话可以注销卡吗)

    打电话可以注销手机卡吗(打电话可以注销卡吗)

  • 华为mate30pro微信聊天记录怎么恢复(华为mate30pro微信照相机模糊怎么设置)

    华为mate30pro微信聊天记录怎么恢复(华为mate30pro微信照相机模糊怎么设置)

  • 下载未完成出现错误是为什么(下载未完成出现错误是怎么办小米手机)

    下载未完成出现错误是为什么(下载未完成出现错误是怎么办小米手机)

  • 路由器显示注册怎么回事(路由器显示注册什么意思)

    路由器显示注册怎么回事(路由器显示注册什么意思)

  • 主存储器又称为什么(主储存器又可以称为)

    主存储器又称为什么(主储存器又可以称为)

  • 抖音显示app版本过低怎么升级(抖音显示版本过低怎么回事)

    抖音显示app版本过低怎么升级(抖音显示版本过低怎么回事)

  • 快手仅好友可见是不是互相关注的人(快手仅好友可见是什么标志)

    快手仅好友可见是不是互相关注的人(快手仅好友可见是什么标志)

  • vivoy83有红外功能吗(vivoy83有没有红外遥控功能)

    vivoy83有红外功能吗(vivoy83有没有红外遥控功能)

  • 实况照片怎么拍3秒(荣耀实况照片怎么拍)

    实况照片怎么拍3秒(荣耀实况照片怎么拍)

  • 应用nnbs有什么用(nw应用程序是啥)

    应用nnbs有什么用(nw应用程序是啥)

  • 华为mate30pro插卡位置(华为mate30pro插卡口在哪里)

    华为mate30pro插卡位置(华为mate30pro插卡口在哪里)

  • 华为怎么换锁屏(华为怎么换锁屏壁纸自定义)

    华为怎么换锁屏(华为怎么换锁屏壁纸自定义)

  • nio和io的区别(nio与io区别)

    nio和io的区别(nio与io区别)

  • qq怎么画画发给别人(qq怎么画画发给别人2022)

    qq怎么画画发给别人(qq怎么画画发给别人2022)

  • 关于将tomcat卸载干净(如何将tomcat卸载干净)

    关于将tomcat卸载干净(如何将tomcat卸载干净)

  • python可以写PPT吗(python可以制作软件吗)

    python可以写PPT吗(python可以制作软件吗)

  • 会员退费怎么算
  • 网银数字证书年费计入什么科目
  • 累计折旧影响所得税费用吗
  • 固定资产加速折旧的方法有哪些
  • 小型制造型企业有哪些
  • 当年实现的利润弥补亏损会计分录
  • 运输费用和保险费用会计分录
  • 职工在异地住院怎么报销
  • 融资性售后回租承租方出售资产为什么不缴纳增值税
  • 增资扩股如何操作
  • 盘亏设备一台
  • 营改增后房地产企业如何开票
  • 食堂开支计入什么科目
  • 个调税手续费会计分录怎么写?
  • 营改增服务业税率
  • 绿化费用明细
  • 营业收入中包括营业外收入吗
  • 企业所得税期间费用明细表
  • 制造费用分摊的账务处理怎么做?
  • 企业购买原材料生产时企业还没有赚到钱
  • 交通定额发票税率
  • 电子发票财务怎么操作
  • 没有认缴到位的股票
  • 电脑有些进程关不掉
  • 汇算清缴专项附加扣除去年忘记填的能补填吗?
  • 总资产收益率什么意思
  • 企业季度税如何申报
  • 资产评估报告包括
  • 预收房租费用计入什么科目
  • 组成计税价格用来算什么
  • win11安装失败0xc1900201
  • win10提示病毒
  • 高新企业研发支出转产成品
  • 个人签订借款合同
  • PHP:imagepsencodefont()的用法_GD库图像处理函数
  • 微信小程序分成比例
  • 多品种生产能力计算公式
  • php 构造方法
  • 发放职工薪酬账务怎么做
  • 初学者安装visual studio
  • python快速检索
  • mysql分区实现
  • 车船税怎么计算
  • 铁路运费的印花税进什么科目
  • u8存货核算对方科目怎么设置
  • python获取某个值
  • pd python
  • 定金罚则可以约定吗
  • 固定资产科目的期末余额,反映固定资产的原价
  • 股东分红要不要纳税?
  • 存单丢失了,去哪里挂失
  • 应交税费属什么类科目
  • 差旅费涉及的科目
  • 劳务派遣公司收入确认税收政策
  • 残保金怎么做账务处理
  • 商场预付卡
  • 工程增值税抵扣比例
  • 销售返利如何做账
  • 银行日记账的登记依据有哪些
  • 减值损失账务处理
  • 公司不做账会怎样?
  • sqlserver2005附加数据库错误1827
  • sql语句查询去重
  • svchost一直在下载什么
  • linux虚拟局域网搭建
  • ie11安装方法
  • Win7旗舰版系统文件名称
  • macbook怎样充电
  • win8电脑远程控制怎么弄
  • win7怎么禁用触摸屏
  • jquery validate
  • js中正则表达式语法
  • mac如何配置pycharm
  • 基于nodejs的框架
  • package.json里面的配置
  • 安徽省国家税务局通用定额发票
  • 广东税务待遇
  • 12333热线时间
  • 北京车过户到廊坊标准
  • 西安代驾平台有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设