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

  • 淘宝48小时不发货怎么赔偿(淘宝48小时不发货会扣分吗)

    淘宝48小时不发货怎么赔偿(淘宝48小时不发货会扣分吗)

  • 怎么看朋友圈是屏蔽了还是删了自己(怎么看朋友圈是否屏蔽了自己)

    怎么看朋友圈是屏蔽了还是删了自己(怎么看朋友圈是否屏蔽了自己)

  • 小米 11不含充电器的标准版和包含充电器的套装版售价相同吗(小米 11不含充电器吗)

    小米 11不含充电器的标准版和包含充电器的套装版售价相同吗(小米 11不含充电器吗)

  • 搜索记录删除了还能找到吗(搜索记录删除了还能找到吗百度)

    搜索记录删除了还能找到吗(搜索记录删除了还能找到吗百度)

  • p30pro的tof镜头怎么用(华为p30的tof镜头怎么开启)

    p30pro的tof镜头怎么用(华为p30的tof镜头怎么开启)

  • qq开通情侣空间别人能看到吗(qq开通情侣空间对方能看到仅自己可见)

    qq开通情侣空间别人能看到吗(qq开通情侣空间对方能看到仅自己可见)

  • 苹果11pro可以用普通充电器充电吗(苹果11pro可以用5G吗)

    苹果11pro可以用普通充电器充电吗(苹果11pro可以用5G吗)

  • mq6m2ch/a是什么版本(mq6w2ll/a是什么版本)

    mq6m2ch/a是什么版本(mq6w2ll/a是什么版本)

  • 微信最近联系人怎么查(微信最近联系人怎么查找)

    微信最近联系人怎么查(微信最近联系人怎么查找)

  • 手机开关键失灵是什么原因(vivo手机开关键失灵)

    手机开关键失灵是什么原因(vivo手机开关键失灵)

  • 为什么微信点赞不见了(为什么微信点赞不了朋友圈)

    为什么微信点赞不见了(为什么微信点赞不了朋友圈)

  • 苹果x摄像头型号(苹果x摄像头长啥样)

    苹果x摄像头型号(苹果x摄像头长啥样)

  • 域名后缀都有什么(域名后缀都有什么字母)

    域名后缀都有什么(域名后缀都有什么字母)

  • 您拨打的电话呼叫前转不成功是什么意思(您拨打的电话呼叫转移什么意思)

    您拨打的电话呼叫前转不成功是什么意思(您拨打的电话呼叫转移什么意思)

  • 固态硬盘怎么看在哪(固态硬盘怎么看参数)

    固态硬盘怎么看在哪(固态硬盘怎么看参数)

  • 淘宝拼团什么时候发货(淘宝什么时候开团)

    淘宝拼团什么时候发货(淘宝什么时候开团)

  • 手机接电话声音小怎么办(手机接电话声音模糊怎么办)

    手机接电话声音小怎么办(手机接电话声音模糊怎么办)

  • 华为圆点悬浮怎么取消(华为圆点悬浮怎么锁屏幕)

    华为圆点悬浮怎么取消(华为圆点悬浮怎么锁屏幕)

  • 荣耀9x支持多少瓦快充(荣耀9x支持多少瓦)

    荣耀9x支持多少瓦快充(荣耀9x支持多少瓦)

  • 华为gt2可以下载app吗(华为gt2可以下载软件吗)

    华为gt2可以下载app吗(华为gt2可以下载软件吗)

  • switch检查是否可以运行软件(ns检查是否可以运行)

    switch检查是否可以运行软件(ns检查是否可以运行)

  • jmmal10是什么型号(jmmal10是什么型号处理器)

    jmmal10是什么型号(jmmal10是什么型号处理器)

  • ctbclick.exe是什么进程 会弹出广告吗 作用是什么 ctbclick进程查询(ctblocker)

    ctbclick.exe是什么进程 会弹出广告吗 作用是什么 ctbclick进程查询(ctblocker)

  • vue3+vite+vant4手机端项目实录(vue手机端)

    vue3+vite+vant4手机端项目实录(vue手机端)

  • 计算土地增值税时允许扣除的项目有
  • 出口退税逾期申报说明怎样写
  • 哪些资产损失应向税务机关申报扣除?
  • 纳税期是多久
  • 可以公账户给私账转账吗
  • 核定征收一般纳什么税
  • 股东分红的账务处理结转
  • 记账凭证核算形式账务处理程序的基本特点
  • 专用发票跨年度能入账吗
  • 增值税系统技术维护费记什么科目
  • 产品售后服务规定
  • 税务稽查执法要以什么为依据,按照法定的职责
  • 哪些出口业务不能做
  • 财务报表提供的信息仅对外部的投资者和债权人有用
  • 电子发票转收入怎么做为记账凭证?
  • 统计机构收到公开申请()内予以答复
  • 小企业流动资产一般是多少
  • 外资公司股东要求
  • mac怎么打印文件内容
  • win8系统如何设置u盘启动
  • 合同印花税的5个税目
  • multiple editions是什么版本
  • 如何做好系统备案工作
  • PHP:mb_ereg_search_pos()的用法_mbstring函数
  • 公司交会费有什么用
  • linux sl
  • php零基础入门教程
  • php_fileinfo作用
  • 双轨制会计核算原则
  • vite config
  • 职工报工伤后用人单位还有赔偿吗
  • 合并报表六大抵消分录
  • 原材料当废品卖出分录
  • 福利费入账要求
  • 猿起信息科技有限公司官网
  • wait等待的用法
  • 代销产品的形式有哪些
  • phpcms v9官网
  • /etc/rc.local添加内容
  • 企业捐赠的资产如何入账
  • 企业自建房出售给员工个人后还需要缴纳土地使用税么
  • 织梦官方网站
  • 预算收入的核算
  • 合并报表少数股东权益是什么
  • 接受捐赠计入
  • 食堂维修费用计入什么科目
  • 生育津贴的支付期限表述不正确的是
  • 建筑行业怎样可以评高工
  • 售后维修的会计分录
  • 计提增值税附加税的账务处理
  • 支付的中介费进什么科目
  • 收到退留抵税额会计分录
  • 物业公司预收的物业费怎么做账
  • 总公司给分公司拨款怎么做账
  • 代收通行费不征税吗
  • 开具红字发票的当月就要进项税额转出吗?
  • 实收资本挂在其他应收款现在股权转让
  • 收到现金货款存入银行会计分录
  • 发票已到款未付怎么做账
  • access数据库sql语言
  • centos7 pptp搭建
  • firefox干啥的
  • windows7 停止服务
  • 360win7
  • MAC修改Dock烟雾效果及设置抓屏快捷键的方法
  • hptasks.exe是病毒吗 是什么进程 hptasks进程说明
  • linux 互传文件
  • node_
  • jQuery插件能输出到控制台
  • jquery div innerhtml
  • unity4.5.3f3 和 Android的通信
  • suse linux 网络配置
  • tree 怎么用
  • bud3d跑酷
  • android反编译软件
  • python异常处理的关键词
  • 山东省税务局在哪
  • 税务人员少征税款
  • 形容有待完善的词语
  • 税务打虚打骗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设