关于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 testA3.在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使用版本不同,监听数据方式不同。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Vuejs 2.0 子组件访问/调用父组件的方法(示例代码)
这篇文章主要介绍了Vuejs 2.0 子组件访问/调用父组件的方法(示例代码),需要的朋友可以参考下2018-02-02
vue中echarts的用法及与elementui-select的协同绑定操作
这篇文章主要介绍了vue中echarts的用法及与elementui-select的协同绑定操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-11-11
前端低代码form-generator实现及新增自定义组件详解
这篇文章主要给大家介绍了关于前端低代码form-generator实现及新增自定义组件的相关资料,form-generator是一个开源的表单生成器,可以帮助我们快速构建各种表单页面,需要的朋友可以参考下2023-11-11
详解从Vue.js源码看异步更新DOM策略及nextTick
本篇文章主要介绍了从Vue.js源码看异步更新DOM策略及nextTick,具有一定的参考价值,感兴趣的小伙伴们可以参考一2017-10-10


最新评论