fix 修复 websocket 非index页面刷新无法重连问题

This commit is contained in:
疯狂的狮子Li
2023-12-23 19:38:34 +08:00
parent 70a3348954
commit 597f2b4461
3 changed files with 13 additions and 13 deletions

View File

@ -19,23 +19,22 @@
*/
import { getToken } from '@/utils/auth';
import useNoticeStore from '@/store/modules/notice';
import { ElNotification } from 'element-plus';
const { addNotice } = useNoticeStore();
let socketUrl: any = ''; // socket地址
let websocket: any = null; // websocket 实例
let heartTime: any = null; // 心跳定时器实例
let socketHeart = 0 as number; // 心跳次数
const HeartTimeOut = 10000; // 心跳超时时间 10000 = 10s
let socketError = 0 as number; // 错误次数
let noticeStore: any = null;
// 初始化socket
export const initWebSocket = (url: any) => {
export const initWebSocket = (url: any, store: any) => {
if (import.meta.env.VITE_APP_WEBSOCKET === 'false') {
return;
}
noticeStore = store;
socketUrl = url;
// 初始化 websocket
websocket = new WebSocket(url + '?Authorization=Bearer ' + getToken() + '&clientid=' + import.meta.env.VITE_APP_CLIENT_ID);
@ -100,7 +99,7 @@ export const sendSocketHeart = () => {
export const reconnect = () => {
if (socketError <= 2) {
clearInterval(heartTime);
initWebSocket(socketUrl);
initWebSocket(socketUrl, noticeStore);
socketError = socketError + 1;
// eslint-disable-next-line prettier/prettier
console.log('socket重连', socketError);
@ -125,7 +124,7 @@ export const websocketonmessage = () => {
if (e.data.indexOf('ping') > 0) {
return;
}
addNotice({
noticeStore.addNotice({
message: e.data,
read: false,
time: new Date().toLocaleString()