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

  • 华为koz-al40是什么型号(华为kozal40价格)

    华为koz-al40是什么型号(华为kozal40价格)

  • 充电器头子滋滋滋滋的声音(充电器头子滋滋响正常吗)

    充电器头子滋滋滋滋的声音(充电器头子滋滋响正常吗)

  • 手机卡怎么办华为手机(手机卡怎么办华为5种方法)

    手机卡怎么办华为手机(手机卡怎么办华为5种方法)

  • 抖音怎么不让人看到自己在线(抖音怎么不让人关注)

    抖音怎么不让人看到自己在线(抖音怎么不让人关注)

  • 苹果执行请求时出错(苹果执行请求时没反应)

    苹果执行请求时出错(苹果执行请求时没反应)

  • 天猫退款商家不处理怎么办(天猫申请退款商家拒绝了怎么还交易成功了)

    天猫退款商家不处理怎么办(天猫申请退款商家拒绝了怎么还交易成功了)

  • 苹果11手机长度多少厘米(苹果11手机长度是)

    苹果11手机长度多少厘米(苹果11手机长度是)

  • 手机收不到4g网络是什么原因(手机突然收不到4g网络)

    手机收不到4g网络是什么原因(手机突然收不到4g网络)

  • cpu fan error什么意思(cpu fan,error)

    cpu fan error什么意思(cpu fan,error)

  • ipad5什么时候出的(ipad什么时候出5g版)

    ipad5什么时候出的(ipad什么时候出5g版)

  • 小米解锁机有什么弊端(小米解锁机有什么风险)

    小米解锁机有什么弊端(小米解锁机有什么风险)

  • word打印快捷键(word打印快捷键怎么添加到工具栏)

    word打印快捷键(word打印快捷键怎么添加到工具栏)

  • 怎么看对方有没有删除你(怎么看对方有没有艾滋病)

    怎么看对方有没有删除你(怎么看对方有没有艾滋病)

  • 华为p30是什么系统(华为p30pro上市价格)

    华为p30是什么系统(华为p30pro上市价格)

  • 苹果max怎么反向充电(苹果max怎么反向充电模式)

    苹果max怎么反向充电(苹果max怎么反向充电模式)

  • oppor15怎么添加桌面插件(oppor15怎么添加nfc功能)

    oppor15怎么添加桌面插件(oppor15怎么添加nfc功能)

  • 默认拨号怎么设置(默认拨号怎么设置手机号)

    默认拨号怎么设置(默认拨号怎么设置手机号)

  • 小红书什么时候能恢复下载(小红书什么时候可以开店的)

    小红书什么时候能恢复下载(小红书什么时候可以开店的)

  • 华为手环能不能测心率(华为手环能不能测血压)

    华为手环能不能测心率(华为手环能不能测血压)

  • 群里面怎么私发一个人(群里面怎么私发信息)

    群里面怎么私发一个人(群里面怎么私发信息)

  • 怎样换输入法(怎样换输入法界面)

    怎样换输入法(怎样换输入法界面)

  • vivoy93快捷菜单在哪里(vivoy93快捷菜单栏在哪里)

    vivoy93快捷菜单在哪里(vivoy93快捷菜单栏在哪里)

  • 苹果手机怎么超过200下不了(苹果手机怎么超级截屏)

    苹果手机怎么超过200下不了(苹果手机怎么超级截屏)

  • iwatch4可以打电话吗(applewatch4能打电话吗)

    iwatch4可以打电话吗(applewatch4能打电话吗)

  • 手机hd1怎么取消(手机hd如何取消)

    手机hd1怎么取消(手机hd如何取消)

  • 30个极致实用的谷歌浏览器插件,让你开发事半功倍(30个极致实用的东西)

    30个极致实用的谷歌浏览器插件,让你开发事半功倍(30个极致实用的东西)

  • 21世纪20年代的ConvNet——ConvNeXt(21世纪20年代的中国)

    21世纪20年代的ConvNet——ConvNeXt(21世纪20年代的中国)

  • 工程预付款的支付要求
  • 增值税附加税包括哪些税种及税率
  • 其他债券投资有减值,为什么其他权益工具投资没有减值
  • 贸易公司的成本有哪些
  • 管理部门社保入哪个科目
  • 中兴通技术维护费
  • 企业收取的租金会计分录
  • 税收的六大作用
  • 固定资产折旧财务
  • 增值税逾期未申报的税务怎么处理
  • 公允价值变动损益会计处理
  • 租赁的土地被征迁
  • 收到款未开发票挂账入什么科目?
  • 小规模应纳税额怎么算
  • 社保补缴上月的在当月扣款
  • 建筑业增值税专票抵扣后的税点是多少
  • 活动策划税费
  • 财税201617号文
  • 银行理财产品属于基金吗
  • 图书对方开具的证明
  • 购置税和购车税一样吗
  • 退休返聘人员的劳动权益保护
  • 工程结算收入的会计分录
  • 华为鸿蒙系统怎么开启
  • 差旅补助需要计提吗
  • 多计提的增值税和附加税怎么冲减?
  • PHP:mb_ereg_match()的用法_mbstring函数
  • 用java写一个helloworld
  • php获取数据
  • 一个实用的php验证
  • 注销公司的处理方式
  • 值得深思的短句
  • 当月没有生产情况正常吗
  • 人工智能内容生成
  • 使用灭火器人要站在上风口还是下风口
  • vnc viewer连接windows
  • ps一个页面怎么选中画板
  • 固定资产损失用什么科目
  • 可转债公允价值变动计入
  • mybatis拦截器执行顺序
  • python缺省函数
  • sql server join
  • sqlserver模糊查询表名
  • 一般纳税人接受捐赠的固定资产,捐赠方提供了有关凭证
  • 资产负债表中应收账款的计算公式
  • 餐饮营业收入怎么算
  • 收到货款发货了没开发票怎么入账
  • 企业所得税中资产计税基础怎么填
  • 研发支出如何做账
  • 银行汇票该怎么做账
  • 应收账款的账期是什么意思
  • 代开发票取得的收入如何入账?
  • 挂靠单位无理要求提供增值税发票怎么办?
  • 外聘人员差旅费用无票调增
  • 出租土地使用权计入什么科目
  • sql to sqlalchemy 转换的小例子
  • w10的产品密钥
  • 无线网卡搜索不到无线网
  • linux文件与目录
  • centos7配置vncserver
  • 为什么我无法更改某些设置电脑
  • javascript的基本语句
  • cocos2d 动画
  • 从零开始咋样
  • perl计算时间差
  • jquery弹出div窗口
  • cls方法可以清除
  • jquery插件使用教程
  • android解析xml的方法中,将整个文件加载到内存
  • jquery中遍历指定的对象和数组是哪个方法
  • js响应鼠标点击不了
  • Warning: Build-tool 17.0.0 is missing AAPT at F:adt-bundle-windows-x86sdk
  • Python注释详解
  • 税务被风控了多久才会解除
  • 已代扣代缴个人所得税,他人还需要缴纳个人所得税吗?
  • 深圳电子税务局app
  • 北京市国家税务局官网手机app
  • 通辽这个地方怎么样
  • 佛山退休办理
  • 企业所得税零申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设