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

  • 厦新负离子空气净化器安装视频(厦新a8)(生态空气负离子)

    厦新负离子空气净化器安装视频(厦新a8)(生态空气负离子)

  • 淘宝叫醒服务怎么开店(淘宝叫醒服务怎么做)

    淘宝叫醒服务怎么开店(淘宝叫醒服务怎么做)

  • 红米note11pro是5g手机吗

    红米note11pro是5g手机吗

  • 小爱音箱怎么使用蓝牙连接(小爱音箱怎么使用qq音乐)

    小爱音箱怎么使用蓝牙连接(小爱音箱怎么使用qq音乐)

  • vivo x27电量百分比怎么设置(vivox21电池容量)

    vivo x27电量百分比怎么设置(vivox21电池容量)

  • 滴滴长途单有空返费嘛(滴滴长途单不付钱怎么办)

    滴滴长途单有空返费嘛(滴滴长途单不付钱怎么办)

  • 淘宝的账户余额在哪里(淘宝的账户余额是不是没有账单)

    淘宝的账户余额在哪里(淘宝的账户余额是不是没有账单)

  • 电脑怎么弄文件夹(电脑怎么弄文件压缩包)

    电脑怎么弄文件夹(电脑怎么弄文件压缩包)

  • 在主页看不到自己发的微博(为什么主页没有看)

    在主页看不到自己发的微博(为什么主页没有看)

  • 小度突然开不了怎么办(小度突然开不了摄像头)

    小度突然开不了怎么办(小度突然开不了摄像头)

  • 抖音被屏蔽是什么状态(抖音屏蔽是什么)

    抖音被屏蔽是什么状态(抖音屏蔽是什么)

  • 华为手机关机后闹钟还会叫吗(华为手机关机后自动开机怎么回事)

    华为手机关机后闹钟还会叫吗(华为手机关机后自动开机怎么回事)

  • 你拨叫的用户暂时无法接通什么意思(你拨叫的用户暂时无人接听请稍后再拨)

    你拨叫的用户暂时无法接通什么意思(你拨叫的用户暂时无人接听请稍后再拨)

  • qq怎么随机匹配聊天(qq怎么随缘匹配)

    qq怎么随机匹配聊天(qq怎么随缘匹配)

  • 苹果ipad最大的屏幕是多大尺寸(苹果ipad最大的屏幕是多大)

    苹果ipad最大的屏幕是多大尺寸(苹果ipad最大的屏幕是多大)

  • 自动转屏在哪里设置(自动转屏在哪里关苹果)

    自动转屏在哪里设置(自动转屏在哪里关苹果)

  • 怎样解除微信自动清理(怎样解除微信自动扣费功能)

    怎样解除微信自动清理(怎样解除微信自动扣费功能)

  • 京东亲情账户怎么弄(京东亲情账户怎么开通)

    京东亲情账户怎么弄(京东亲情账户怎么开通)

  • 快手戳一下对方能看见吗(快手戳一下对方收到什么提示)

    快手戳一下对方能看见吗(快手戳一下对方收到什么提示)

  • mybatis #和$区别(mybatis#$的区别)

    mybatis #和$区别(mybatis#$的区别)

  • 商家怎么修改配送范围(商家怎么修改配送费)

    商家怎么修改配送范围(商家怎么修改配送费)

  • iphone重启快捷键(苹果重启快捷键在哪里)

    iphone重启快捷键(苹果重启快捷键在哪里)

  • 苹果xr开机键在哪里(苹果手机xr开机键)

    苹果xr开机键在哪里(苹果手机xr开机键)

  • x27pro和x27的区别(x27pro与x27区别)

    x27pro和x27的区别(x27pro与x27区别)

  • agfaclnk.exe进程有什么作用 agfaclnk是什么进程(打开进程失败)

    agfaclnk.exe进程有什么作用 agfaclnk是什么进程(打开进程失败)

  • 用于员工福利的进项税转出分录
  • 个人独资企业和个体工商户的税收区别
  • 应预缴税款如何计算?
  • 增值税纳税申报表电子版在哪下载
  • 购进货物用于建造厂房可以抵扣增值税吗
  • 购入不动产进项税额抵扣
  • 小规模旅行社差额征税的账务处理
  • 递延收益税务处理方法
  • 项目清算组
  • 抵押贷款评估费用标准
  • 招待费的增值税专用发票可以抵扣吗
  • 增值税专用发票可以开电子发票吗
  • 加工企业如何降成本
  • 小规模收到货运专用发票
  • 企业间借款利息开票税目
  • 个人购买余额宝安全吗?
  • 幼儿园收的保教费是什么费
  • 高新技术的研发收入是多少才可以提高
  • mac dock不见了
  • 默认网关不可用的解决办法
  • windows更新暂停怎么恢复
  • 商品流通企业会计科目表
  • 向银行贷款资金成本率计算公式是什么
  • 分红派息钱去哪里了
  • php中实现文件上传需要用到哪几个函数
  • 收费公路通行费补费平台 APP
  • 汽车客运补充车道标志
  • 毕业设计2022年幼儿园
  • calc下载
  • 小微企业声明函去哪个部门开
  • 应付票据贴现是负债吗
  • 最好最实用的织毛线
  • 向境外股东分配股息预提所得税
  • 计提折旧的固定资产平均总值怎么算
  • 预包装的标签有哪几种
  • 个人承担的个税是公司的成本费用吗
  • 应纳税调增调减科目是什么
  • 清算中的企业能恢复吗
  • 房屋免租期的房子能卖吗
  • 以前年度损益调整是什么意思
  • 流动比率好说明什么
  • 应收票据的分录怎么做
  • 财务报表中的净利润
  • 什么是盈余公积和资本公积
  • 去年支付的费用,今年收到发票可以入账吗
  • 发票抵扣联要放在凭证里面吗
  • 职工教育经费如何列支
  • 水表怎么借水
  • 没有对公业务的银行
  • 财务预算编制方法包括
  • 个体户不交税会判刑吗?
  • 建账及账务处理步骤
  • mysql安装与配置的步骤与常用命令
  • 怎么用u盘装驱动
  • windows server vista
  • linux如何用
  • arch linux安装yay
  • linux的rz sz命令
  • net 4.0.30319
  • linux系统中安装软件的批处理文件
  • win7系统关闭开机启动项设置
  • win8系统运行慢怎么办
  • win8怎样设置将文件保存到d盘
  • win7如何升级到win10有什么要求
  • linux备份恢复
  • win7系统安装谷歌浏览器
  • opengl 模型
  • 使用jquery实现的项目
  • linux防火墙开启80端口视频
  • 清除电脑开机痕迹
  • unity系统错误
  • 批处理编程教程
  • 为了防止编码过程的过载现象出现
  • 关于jQuery中的DOM操作,下列哪种方法用来复制元素?
  • 刀具路径轨迹模拟
  • 公务员副处级工资待遇
  • 江苏省国税总局
  • 保险的佣金一般是多少
  • 济南税务稽查局人员名单
  • 汽车购置税退税需要多长时间
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设