这篇文章主要讲解了vue-socket.io接收不到数据问题怎么办,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
最近公司的一个vue项目用到了vue-socket.io来处理socket数据传输,之前用过socket.io-client,现在知道vue-socket.io是基于socket.io-client的一层封装,将socket挂于全局从而更方便的书写。
于是把代码拉取下来运行:
什么鬼,同样的代码为什么我的就接收不到数据,自己新建一个测试一下吧!
先用express和socket.io搭个小socket服务器:
let express = require('express');
let app = express();
let server= require('http').Server(app);
let io = require('socket.io')(server);
io.on('connect', (socket) => {
setInterval(() => {
socket.emit('hi','hello')
},2000)
socket.on('hello', (data) => {
console.log('hello',data)
socket.emit('hi','get it')
})
socket.on('disconnect', (data) => {
console.log('断开', data)
})
})
server.listen(8080);
再搭个vue-cli3环境,main.js里use一下socket:
import Vue from 'vue'
import App from './App.vue'
import VueSocketIO from 'vue-socket.io'
Vue.config.productionTip = false
Vue.use(new VueSocketIO({
debug: true,
connection: 'http://127.0.0.1:8080',
}))
new Vue({
render: h => h(App),
}).$mount('#app')
再去组件里监听一下:
<script>
export default {
sockets: {
connect() {
console.log('链接成功');
},
disconnect() {
console.log('断开链接')
},
reconnect() {
console.log('重新链接')
},
hi(res) {
console.log('VueSocketIO', res)
}
}
}
</script>
结果:
为什么,是socket数据没发送过来吗?我装个socket.io-client试试:
import io from 'socket.io-client'
export default {
mounted() {
io('http://127.0.0.1:8080').on('hi', (res) => {
console.log('socket.io-client', res)
})
},
}
没问题,数据传过来了,但vue-socket.io为啥不行,不管了,先向服务端发送一条信息看能不能收到:
this.$socket.emit('hello','i am wk')
没问题,收到了,所以现在是socket已经连接上了,客户端可以向服务端正常发送数据,但服务端也向客户端发送数据了,上面用socket.io-client可以正常接收已经证明这一点了,问题是vue-socket.io没有正确写法去接收数据,似乎api上的写法出bug了。
打印一下this发现因为引入vue-socket.io的原因,this上面挂了一个sockets属性:
this.sockets下有一个listener属性,看这个名字就感觉有戏,试一下:
this.sockets.listener.subscribe('hi', (data) => {
console.log('++++++++++',data)
})
看完上述内容,是不是对vue-socket.io接收不到数据问题怎么办有进一步的了解,如果还想学习更多内容,欢迎关注天达云行业资讯频道。