vue|vue 项目中使用websocket的正确姿势
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|vue 项目中使用websocket的正确姿势】到此这篇关于vue 项目中使用websocket的文章就介绍到这了,更多相关vue使用websocket内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- VUE项目中封装Echart折线图的方法
- vue+echarts实现3D柱形图
- 项目打包成jar后包无法读取src/main/resources下文件的解决
- vue+echarts实带渐变效果的折线图
- vue-cli3.0如何修改端口号
- “敏捷项目比传统项目快”这个说法对吗()
- Docker部署项目完全使用指南(小结)
- 如何利用Vue+Element做个小页面
- vue进行post和get请求实例讲解
- vue恢复初始数据this.$data|vue恢复初始数据this.$data,this.$options.data()解析