vue3使用socketio的简单例子

后端是使用的springboot,socketio版本为1.7.11

<dependency>
    <groupId>com.corundumstudio.socketio</groupId>
    <artifactId>netty-socketio</artifactId>
    <version>1.7.11</version>
</dependency>

由于后端版本问题,前端socketio安装版本不能太高,不然就会连接不上,这个问题也是查了很久才发现是版本问题

npm install socket.io-client@2.3.1

io.js

import io from 'socket.io-client'
const socket = io('http://127.0.0.1:9096', {
    query: {},
    transports: ['websocket', 'polling'],
    timeout: 5000,
})
export default socket

mian.js中引用

import { createApp } from 'vue'
import socket from './utils/io'

const app = createApp(App);
app.mount('#app')
app.config.globalProperties.$socket = socket;

页面中使用

<script lang="ts">
import {defineComponent,ref,getCurrentInstance,onMounted,onUnmounted } from 'vue'
export default defineComponent({
    setup(){
      const { proxy  }: any = getCurrentInstance()
      onMounted(() => {
        proxy.$socket.on('connect',()=>{
          console.log('socketio-connect')
        })
        proxy.$socket.on('message',(data) =>{
          console.log(data)
        });
      });
      onUnmounted(() => {
        proxy.$socket.removeAllListeners('connect');
        proxy.$socket.removeAllListeners('message');
      });
      let sendMessage = ()=>{
          console.log('发送消息')
          proxy.$socket.emit('message', {
              msgContent: "你好!" + new Date()
          });
      }
        return {
          sendMessage
        }
    }
})
</script>

有问题的地方欢迎指出

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值