vue3+ts+Vuex中如何使用websocket协议

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>
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3使用Vuex时,可以借助辅助函数进行封装。你可以参考提到的深入Vue3 TypeScript技术栈-coderwhy大神新课视频学习来改写你的代码。具体的目录结构可以按照以下方式进行组织: 在index.ts文件,引入以下辅助函数: ``` import { useGetters } from './useGetters' import { useMutations } from './useMutations' import { useState } from './useState' import { useActions } from './useActions' export { useGetters, useState, useMutations, useActions } ``` 在使用Vuex的地方,你可以参考给出的示例代码进行修改。在Vue2,我们使用`...mapState`、`...mapGetters`、`...mapMutations`和`...mapActions`进行映射。在Vue3,可以通过使用自定义的辅助函数来代替。 对于ts方面的变化,你需要做以下两个改变: 1. 在导入`useStore`时,需要修改为`import { useStore } from '../store'`,具体路径根据你的项目结构来确定。 2. 在定义自己的`useStore`组合式函数时,需要修改为`export function useStore () { return baseUseStore(key) }`,其`key`可以按照你自己的需求进行导出。 此外,你还需要根据你的具体需求来修改`createStore`的状态、getters、mutations和actions等。 以上是关于在Vue3使用Vuex的一些变化和调整,请根据你的具体情况进行相应的修改。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue3+ts 使用 vuex辅助函数(mapState,mapMutations,mapGetters,mapActions) 对函数进行二次封装](https://blog.csdn.net/weixin_43245095/article/details/123380948)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [vue3+Ts使用vuex模块化和非模块化管理的2种方式(非pinia)](https://blog.csdn.net/weixin_45441173/article/details/128510971)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值