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

  • 淘宝又崩了是怎么回事(淘宝崩了怎么回事)

    淘宝又崩了是怎么回事(淘宝崩了怎么回事)

  • 企业在执行微信营销策略规划的八大步骤(企业在执行微信上怎么办)

    企业在执行微信营销策略规划的八大步骤(企业在执行微信上怎么办)

  • 怎样利用邮件群发来提高成交量(怎么用邮箱群发邮件)

    怎样利用邮件群发来提高成交量(怎么用邮箱群发邮件)

  • iphone13手电筒在哪(苹果13手机的手电筒)

    iphone13手电筒在哪(苹果13手机的手电筒)

  • v1930a是什么型号(v1932a是什么型号)

    v1930a是什么型号(v1932a是什么型号)

  • 恢复对方微信撤回语音(恢复对方微信撤回消息软件)

    恢复对方微信撤回语音(恢复对方微信撤回消息软件)

  • 打印出来跟排版不一致(打印出来跟排版不一致什么原因)

    打印出来跟排版不一致(打印出来跟排版不一致什么原因)

  • 戴尔开机蓝屏0x0000007b(戴尔开机蓝屏0x0怎么解决)

    戴尔开机蓝屏0x0000007b(戴尔开机蓝屏0x0怎么解决)

  • 微信视频号每个人都有吗(微信视频号每个视频浏览量有多少个)

    微信视频号每个人都有吗(微信视频号每个视频浏览量有多少个)

  • 苹果手机听语音怎么切换扬声器(苹果手机听语音声音小怎么办)

    苹果手机听语音怎么切换扬声器(苹果手机听语音声音小怎么办)

  • 8G内存条能装win764位系统吗(8g内存支持系统吗)

    8G内存条能装win764位系统吗(8g内存支持系统吗)

  • qq拒收对方消息对方会显示什么(qq拒收对方消息设置)

    qq拒收对方消息对方会显示什么(qq拒收对方消息设置)

  • iphonex要不要更新13.3

    iphonex要不要更新13.3

  • 智能剪辑是什么意思(智能剪辑怎么用)

    智能剪辑是什么意思(智能剪辑怎么用)

  • 手机被别人举报停机怎么办(手机被别人举报怎么办)

    手机被别人举报停机怎么办(手机被别人举报怎么办)

  • 乐科智控是什么(乐科智控是什么意思?)

    乐科智控是什么(乐科智控是什么意思?)

  • 回收降权淘宝号有什么用(人家收降权淘宝号有什么用)

    回收降权淘宝号有什么用(人家收降权淘宝号有什么用)

  • ps色相饱和度着色作用(ps色相饱和度怎么调色)

    ps色相饱和度着色作用(ps色相饱和度怎么调色)

  • ipad3可以插内存卡吗(ipad3支持内存卡吗?)

    ipad3可以插内存卡吗(ipad3支持内存卡吗?)

  • 手机照片怎么重命名jpg(手机照片怎么重命名)

    手机照片怎么重命名jpg(手机照片怎么重命名)

  • vivoy93怎么回主页(vivo手机怎样回到主屏幕)

    vivoy93怎么回主页(vivo手机怎样回到主屏幕)

  • qq封了7天怎么能解除(qq封了7天怎么能解封)

    qq封了7天怎么能解除(qq封了7天怎么能解封)

  • 哔哩哔哩如何下载视频(打开哔哩哔哩)

    哔哩哔哩如何下载视频(打开哔哩哔哩)

  • 电脑桌面任务栏跑到左边去了(电脑桌面任务栏跑到上面去了怎么还原)

    电脑桌面任务栏跑到左边去了(电脑桌面任务栏跑到上面去了怎么还原)

  • 年度企业所得税会计分录怎么做
  • 开票和预缴税款跨月
  • 贸易公司的成本有哪些
  • 签订合同后付款
  • 红字信息表跨月撤销有什么影响吗
  • 配件的出口是否可以免抵退?
  • 周转材料核算科目是什么
  • 公司名义看望病人合法吗
  • 企业所得税汇算清缴网上申报流程
  • 税务大厅补报个税怎样申报
  • 小规模企业所得税优惠政策最新2023
  • 房地产停车场属于公共配套设施吗
  • 劳务公司的主营业务成本是人工工资需要个人开发票吗?
  • 不应该计入管理费用的
  • 外购产品检验流程
  • 自然人税收管理系统扣缴客户端app
  • 销售劳务的税率是多少
  • 小企业递延收益计算公式
  • 递延收益摊销会计分录
  • 如何在Excel中计算平均值
  • php ftell
  • 土地增值税的计税依据
  • win10系统多任务功能的快捷键
  • 退货会计应该怎么做账
  • 分手我不怕
  • 个人买车缴纳车船税吗
  • 企业资本结构决策需要重点考虑的有
  • 出口免抵增值税是什么意思
  • 新手会计怎么做帐
  • php常用命令
  • php函数作用
  • 腾讯一面问什么
  • css3的模块结构和应用
  • node.js的安装和配置
  • laravel分页
  • hash操作
  • 视同销售收入税法处理?
  • 公司承担员工的费用,员工违规吗
  • 设备安装工程验收规范
  • 上期金额是本年累计金额吗
  • 农业用肥尽量不选择
  • 企业的净资产都有哪些
  • 员工出差预借差旅费入的借贷
  • 企业所得税计算器在线计算
  • 个人所得税专项扣除2023最新政策
  • mysql在表中添加一个新的属性
  • 支付员工的餐费怎么入账
  • 资本公积占比多少合适
  • 买一赠一是什么促销方式
  • 一般纳税人适用什么会计准则
  • 消费税会计处理的设置
  • 完工产品成本计算表怎么填
  • 公司账户转法人个人账户需要交税吗
  • 盈余公积转增资本对会计要素的影响
  • 企业存货明细表和盘点表
  • 库存商品差额调整会计目录
  • 财务报表分析的主体是
  • 满减送的购物券在哪里看
  • 工程费用科目
  • 会计核算采用什么形式
  • 残保金是交上一年的吗
  • 固定资产为什么提折旧,有何实际意义
  • 商业企业会计制度变迁论文
  • sql搜索字段名
  • sql空值用什么表示
  • 任务栏都不见了
  • ami 2.17.1254bios设置图解教程
  • win10新版cortana
  • csinsm32.exe是安全的进程吗 csinsm32进程有哪些用处
  • win8怎么设置ip地址
  • s24evmon.exe - s24evmon是什么进程 有什么用
  • mac版本itunes
  • linux系统获取dhcp地址
  • windows8怎么使用
  • 着色器问题
  • bootstrap滚动监听效果
  • linux用yum
  • python中__init__
  • javascript中如何获取元素?
  • 领导班子和领导干部评议意见表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设