最详细的vue-socket.io用法

本文详细介绍了如何在Vue项目中使用vue-socket.io,包括静态和动态地址的连接设置,以及解决连接、断开和重连问题。特别强调了在地址动态情况下,确保正确执行连接操作的技巧,如使用定时器避免渲染顺序导致的问题,并提供了关键事件的监听示例。
摘要由CSDN通过智能技术生成

     通过最近一系列的踩坑之后,总结出了这篇相对较为完善的关于vue-socket.io的使用文章,包含大家困扰的(socket连接、断开重连,以及当连接的地址是动态的情况下,我们应该注意的事项


一.下载vue-socket.io

    npm install vue-socket.io --save

二.引入到vue-cli项目中

        引入的方式有两种情形,具体根据你们的项目需求来做

 a.第一种情景:webSocket连接的地址是固定的

在main.js中直接这样写

import VueSocketIO from 'vue-socket.io'

Vue.use(new VueSocketIO({

    debug: true,

    connection: 'http://metinseylan.com:1992',  //

}))

在这里我有句话要说,我百度出来的,连接方式很多直接在main.js中如下这样写:

import VueSocketio from 'vue-socket.io'; 

Vue.use(VueSocketio, 'http://socketserver.com:1923');              //*****这种方法我试了,我这边不行***//

如果有大神知道原因,可在评论下方告诉我哦

 b.第二种情形:webSocket连接的地址的是动态的,是后台通过接口传给我们的

如图所示

  **这里要提示的一点就是,当连接的地址是动态的,代码的执行顺序就很重要了,即new VueSocket在main.js中的位置**

三.在mounted中执行connect

a.当socket地址是静态的写法

mounted(){

this.$socket.emit('connect', 1)

}

b.当socket地址是动态的

因为此时的socket连接地址是动态的,就会存在请求响应然后渲染的时间,这个时候就会出现socket还没渲染成功就执行了App.vue,这时候connect连接事件就不会触发,所以采用定时器的方法来执行connect

mounted() {

    var timerOne = window.setInterval(() => {

      if (this.$socket) {

        this.$socket.emit('connect', 1)

        window.clearInterval(timerOne)

        return;

      }

    }, 500)

  },

四,推送消息给后台,连接socket

五、socket连接成功

因为我们在  new VueSocketIO中开启了debug: true,就会在控制台中出现那些蓝色字体,来帮助我们调试socket,注意,如果蓝色的字中,没有包含我们在socket中定义的事件(connect、users、reconnect......),那就可能是我们在main,js中创建的new VueSocketIO渲染时间有问题,这个时候,connect事件也不会执行

后台定义的事件

如图上所示user、transferMessage这些名词,都是后台自定义的,每个项目中可能都会有所不同,我们接受消息的事件就是靠后台来告诉我们的

vue-socket.io中自带的几个事件

connect:查看socket是否渲染成功 

disconnect:检测socket断开连接 

reconnect:重新连接socket事件

以上就是所有啦,有问题可评论区见,如以上文章有错误地方,也可评论区指出......

Vue2使用vue-socket.io可以实现与Socket.io的集成,实现实时聊天等功能。首先,需要在项目中引入vue-socket.io扩展,可以通过npm安装vue-socket.io并引入。 在Vue实例中,使用Vue.use()来注册并使用Vue-socket.io。在注册时,需要传入相应的配置参数,包括debug、connection、vuex等。其中,debug用于调试,可以选择关闭;connection用于指定Socket.io的连接地址;vuex用于在Vuex中使用Socket.io的事件监听。 具体实现步骤如下: 1. 首先,安装vue-socket.io扩展:npm install vue-socket.io 2. 在Vue实例中引入VueVueSocketIO,并配置相应的参数。 3. 创建Vuex store,并在配置参数中指定vuex为store的实例。 4. 在Vue实例中使用Vue.use()注册Vue-socket.io,并传入配置参数。 这样,Vue2就可以使用vue-socket.io扩展来实现与Socket.io的集成了。可以使用Vue-socket.io提供的方法来监听Socket事件,并实现相应的功能。 总结一下,Vue2使用vue-socket.io扩展可以实现与Socket.io的集成,通过注册Vue-socket.io并传入相应的配置参数,可以在Vue实例中实现Socket事件的监听和处理。这样就可以实现实时聊天等功能了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Vue 使用 Vue-socket.io 实现即时聊天应用(vuex管理)](https://blog.csdn.net/weixin_47746452/article/details/121330186)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [vue-socket.io-extended:Vue.jsVuex的Socket.io绑定(受Vue-Socket.io启发)](https://download.csdn.net/download/weixin_42160425/18170249)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Vue 使用 Vue-socket.io 实现即时聊天应用(实战篇 一)](https://blog.csdn.net/weixin_47746452/article/details/121359940)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值