vue项目中使用websocket的实现
什么是websocket?
“WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。
WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在 WebSocket API 中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。
在 WebSocket API 中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。”
1. 在utils下新建websocket.js文件
// import { showInfoMsg, showErrorMsg } from '@/utils/popInfo'import ElementUI from 'element-ui'; function initWebSocket(e) {console.log(e)const wsUri = WS_API + "/webSocket/" + e; this.socket = new WebSocket(wsUri)//这里面的this都指向vuethis.socket.onerror = webSocketOnError; this.socket.onmessage = webSocketOnMessage; this.socket.onclose = closeWebsocket; }function webSocketOnError(e) {ElementUI.Notification({title: '',message: "WebSocket连接发生错误" + e,type: 'error',duration: 0,}); }function webSocketOnMessage(e) {const data = https://www.it610.com/article/JSON.parse(e.data); console.log(data.msgType ==="INFO", data.msgType === "INFO")if (data.msgType === "INFO") {ElementUI.Notification({title: '',message: data.msg,type: 'success',duration: 3000,}); } else if (data.msgType === "ERROR") {ElementUI.Notification({title: '',message: data.msg,type: 'error',duration: 0,}); }}// 关闭websiocketfunction closeWebsocket() {console.log('连接已关闭...')}function close() {this.socket.close() // 关闭 websocketthis.socket.onclose = function (e) {console.log(e)//监听关闭事件console.log('关闭')}}function webSocketSend(agentData) {this.socket.send(agentData); }export default {initWebSocket, close}
文章图片
文章图片
如果想刷新重新链接websocket 可以在App.vue页面里添加个钩子函数
mounted() {//当在任一路由页面被刷新时,便是根组件app被从新建立,此时能够进行webSocket重连//从localStorage中获取用户信息,是登陆状态则能够进行webSocket重连let token = localStorage.getItem("token"); if (token) {// userMessage = JSON.parse(userMessage); this.$websocket.initWebSocket(token); }},
文章图片
客户端主动关闭websocket 在关闭的地方触发函数就可以
logout() {// localStorage.clear(); localStorage.removeItem("token"); this.$websocket.close(); this.$store.dispatch("LogOut").then(() => {location.reload(); }); },
文章图片
注:$webSocket 是在main.js中全局注册了websocket.js文件
文章图片
【vue项目中使用websocket的实现】 到此这篇关于vue项目中使用websocket的实现的文章就介绍到这了,更多相关vue使用websocket内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 如何在 Vue 中使用 Chart.js - 手把手教你搭可视化数据图表
- 基于SpringBoot框架和VUE的求职招聘系统
- 前端|913 error Component name “home“ should always be multi-word vuemulti-word-component-names
- 12|12 款最棒 Vue 开源 UI 库测评 - 特别针对国内使用场景推荐
- 免费硬件、专属导师、豪华大礼|AI达人创造营第二期项目征集启动啦!
- 用Assert(断言)封装异常,让代码更优雅(附项目源码)
- 前端|IDEA安装element-ui报错npm ERR Found vue@3.2.26npm ERR node_modulesvuenpm ERR vue@“^3.0.0“ from
- 人工智能-Python实现多项式回归
- Springboot中项目的属性配置的详细介绍
- C语言|C语言项目实践——通讯录(三版本联合分解)