vue中如何使用websocket

正所谓,知己知彼,百战不殆。在使用之前先来了解一下websocket吧!

1. 什么是WebSocket

WebSocket是一种网络传输协议,可在单个TCP连接上进行全双工通信,位于OSI模型的应用层。
WebSocket协议在2011年由IETF标准化为RFC 6455,后由RFC 7936补充规范。Web IDL中的WebSocket API由W3C标准化。

WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。

在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就可以创建持久性的连接,并进行双向数据传输。

2. 为什么需要websocket?

​ 前端和后端的交互模式最常见的就是前端发数据请求,从后端拿到数据后展示到页面中。如果前端不做操作,后端不能主动向前端推送数据,这也是http协议的缺陷。

因此,一种新的通信协议应运而生—websocket,他最大的特点就是服务端可以主动向客户端推送消息,客户端也可以主动向服务端发送消息,实现了真正的平等。

http与websocket区别

websocket其他特点如下:

(1)建立在 TCP 协议之上,服务器端的实现比较容易。

(2)与 HTTP 协议有着良好的兼容性。默认端口也是80和443,并且握手阶段采用 HTTP 协议,因此握手时不容易屏蔽,能通过各种 HTTP 代理服务器。

(3)数据格式比较轻量,性能开销小,通信高效。

(4)可以发送文本,也可以发送二进制数据。

(5)没有同源限制,客户端可以与任意服务器通信。

(6)协议标识符是ws(如果加密,则为wss),服务器网址就是 URL。

3. 兼容情况

websocket的兼容情况

从上图可以看到,现代浏览器都支持WebSocket(包括IE、纯现代浏览器),移动端支持情况良好,所以不用过于担心兼容问题,如果很不巧碰到需要进行兼容性处理,请参考 如何解决WebSocket的兼容性

4. vue中引用websocket

在vue项目中使用websocket需要注意以下几点:

(1)首先需要判断浏览器是否支持websocket(虽然websocket兼容性相对较好,但不可不防呐)

(2)在组件加载的时候连接websocket,在组件销毁的时候断开websocket

(3)后端接口需要引入socket模块,否则不能实现连接

示例完整代码如下:

<template>
  <div class
  • 19
    点赞
  • 152
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Vue Websocket是一种在Vue框架使用Websocket库,它允许我们在应用程序使用Websocket连接,并快速地构建实时应用程序。Vue Websocket可以与任何Websocket服务器一起使用,并提供了一些方便的功能,例如自动重新连接、保持心跳、重试和/或延迟连接,以确保Websocket连接始终正常运行。 Vue Websocket提供了一种快速、轻量级的方式来使用Websocket,这使得我们可以轻松地为现有的Vue应用程序添加实时功能。例如,我们可以使用Vue WebsocketVue应用程序实现实时聊天室、实时通知或实时图表。此外,Vue Websocket还支持许多自定义配置选项,以适应各种项目需求。 在使用Vue Websocket之前,我们需要确保我们的Websocket服务器正常运行,并已启动一条Websocket连接。然后,我们可以使用Vue Websocket库的API来设置连接选项、定义回调函数、监听Websocket事件等。一旦我们建立了Websocket连接,我们就可以在Vue组件使用Vue Websocket插件提供的实时数据,来动态地更新我们的UI或响应用户交互。 总的来说,Vue Websocket是一个灵活、高效、易于使用Websocket库,它使我们可以快速构建实时应用程序,并为我们提供了许多有用的功能和选项。无论是构建大型企业应用程序、实时游戏、通知系统,还是更简单的实时应用程序,Vue Websocket都可以大大简化我们的工作,同时提供可靠性和灵活性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值