关于vue-socket.io使用及版本原因消息无法监听bug

 更新时间:2022年10月18日 14:47:16   作者:菑恩_  
这篇文章主要介绍了关于vue-socket.io使用及版本原因消息无法监听bug,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

前言

主要记录vue-socket.io使用,以及使用版本不同导致消息无法监听问题。

一、vue-socket.io使用

1.npm下载

npm install vue-socket.io --save-dev

2.在src文件夹里面新建lib文件夹

在lib文件夹里面新建socket.js

代码如下(示例):

import Vue from 'vue'
import VueSocketIO from 'vue-socket.io'
import { getToken } from "../../libs/util";
let testA;
let wesocket = {
  debug: true,
  connection: ''
}
function getSocket (t) {
  console.log('地址',process.env.VUE_APP_SOCKET)
  var socketIp = process.env.VUE_APP_SOCKET// socket地址\
  wesocket.connection = socketIp
  if (getToken() || t) { // 判断是否有token  tokenId  sessid
    let tk = getToken() ? getToken() : t
    wesocket.connection = socketIp + '?sessid=' + tk
  }
  wesocket.debug = true // 是否开启控制台监听打印数据
  if (wesocket.connection != '') {
    Vue.use(new VueSocketIO(wesocket))
  }
}
getSocket();
//挂在在全局prototype上
Vue.prototype.$getSocket = getSocket

export default testA

3.在main.js引入

代码如下(示例):

import VueSocketIO from './lib/socket'  
new Vue({  
    el: '#app',  
    VueSocketIO,  
    components: {  
    App  
},  
template: '<App/>'  10.    })

4.在组件中的用法

代码如下(示例):

//跟methods同级 
sockets: {
   connect: function () {
       console.log('connect====连接');
  },
   // 监听断开连接,函数
   disconnect() {
       console.log('disconnect====监听断开连接')
   },
   reconnect () {
       console.log('reconnect====再连接')
   },
   msginfo: function (data) {
       let jsonObj = JSON.parse(data) ;
       console.log('jsonObj++++++++++',jsonObj)
   },
   msginfoTip: function (data) { // socket获取冒泡信息
       let data1 = JSON.parse(data);
       let _this = this
       // console.log('data1获取冒泡信息',data1)
   }
}

注意: vue-socket.io3.07版本及以下版本可以这样使用,能连接并且有数据返回,但是vue-socket.io3.08,3.09有bug连接了但是接收不到数据。

二、版本导致消息无法监听问题 

vue-socket.io3.07版本及以下版本可以这样使用,能连接并且有数据返回,但是vue-socket.io3.08,3.09有bug连接了但是接收不到数据。

在3.0.8和3.0.9下这样写无效

3.0.8和3.0.9要像下面一样写 利用listener来监听

代码如下(示例):

this.sockets.listener.subscribe('connect', (data) => {
  console.log('connect连接成功')
})

this.sockets.listener.subscribe('msginfo', (data) => {
  console.log('数据监听msginfo',data)
})

this.sockets.listener.subscribe('msginfoTip', (data) => {
  console.log('数据监听msginfoTip',data)
})

总结

vue-socket.io使用版本不同,监听数据方式不同。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue中的attribute和property的具体使用及区别

    vue中的attribute和property的具体使用及区别

    本文主要介绍了vue中的attribute和property的具体使用及区别,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • vue环形进度条组件实例应用

    vue环形进度条组件实例应用

    在本文中我们给大家分享了关于vue环形进度条组件的使用方法以及实例代码,需要的朋友们跟着测试下吧。
    2018-10-10
  • 详解如何使用router-link对象方式传递参数?

    详解如何使用router-link对象方式传递参数?

    这篇文章主要介绍了如何使用router-link对象方式传递参数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • vue中记录滚动条位置的两种方法

    vue中记录滚动条位置的两种方法

    最近用 Vue 做移动端页面遇到一个问题,需要记住滚动条的位置,所以下面这篇文章主要给大家介绍了关于vue中记录滚动条位置的两种方法,文中给出了详细的实例,需要的朋友可以参考下
    2023-01-01
  • vue3+ts使用APlayer的示例代码

    vue3+ts使用APlayer的示例代码

    这篇文章主要介绍了vue3+ts使用APlayer的示例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08
  • 如何去除element-ui中table的hover效果

    如何去除element-ui中table的hover效果

    这篇文章主要介绍了如何去除element-ui中table的hover效果,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • vue 实现Web端的定位功能 获取经纬度

    vue 实现Web端的定位功能 获取经纬度

    这篇文章主要介绍了vue 实现Web端的定位功能获取经纬度,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • vue el-table 动态添加行与删除行的实现

    vue el-table 动态添加行与删除行的实现

    这篇文章主要介绍了vue el-table 动态添加行与删除行的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Vue按时间段查询数据组件使用详解

    Vue按时间段查询数据组件使用详解

    这篇文章主要为大家详细介绍了Vue按时间段查询数据组件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • ElementUI下拉框选择后不显示值问题及解决

    ElementUI下拉框选择后不显示值问题及解决

    这篇文章主要介绍了ElementUI下拉框选择后不显示值问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02

最新评论