vue3使用vue-native-websocket-vue3通讯
插件使用
安装
npm install vue-native-websocket-vue3 --save
如果你的项目启用了TypeScript,则在main.ts文件中导入并使用插件。
没有启用就在main.js中导入并使用。
使用插件时,第二个参数为必填项,是你的websocket服务端连接地址。
插件必须依赖于Vuex或者pinia任选其一即可。
import VueNativeSock from "vue-native-websocket-vue3";
// 使用VueNativeSock插件,并进行相关配置
app.use(VueNativeSock,"");
一、启用Vuex集成
1.在mian.js中
import VueNativeSock from "vue-native-websocket-vue3";
import store from "/@/store";
app.use(VueNativeSock, '你的websocket服务端连接地址', {
// 启用pinia集成 | enable pinia integration
store: store,
// 数据发送/接收使用使用json
format: "json",
// 开启手动调用 connect() 连接服务器
connectManually: true,
// 开启自动重连
reconnection: true,
// 尝试重连的次数
reconnectionAttempts: 5,
// 重连间隔时间
reconnectionDelay: 3000
});
export default app;
2.store/index.js文件中
import { createStore } from "vuex";
import main from "../main";
export default createStore({
state() {
return {
socket: {
// 连接状态
isConnected: false,
// 消息内容
message: "",
// 重新连接错误
reconnectError: false,
// 心跳消息发送时间
heartBeatInterval: 50000,
// 心跳定时器
heartBeatTimer: 0
}
};
},
mutations: {
// 连接打开
SOCKET_ONOPEN(state, event) {
main.config.globalProperties.$socket = event.currentTarget;
state.socket.isConnected = true;
// 连接成功时启动定时发送心跳消息,避免被服务器断开连接
state.socket.heartBeatTimer = window.setInterval(() => {
const message = "心跳消息";
state.socket.isConnected &&
main.config.globalProperties.$socket.sendObj({
code: 200,
msg: message
});
}, state.socket.heartBeatInterval);
},
// 连接关闭
SOCKET_ONCLOSE(state, event) {
state.socket.isConnected = false;
// 连接关闭时停掉心跳消息
clearInterval(state.socket.heartBeatTimer);
state.socket.heartBeatTimer = 0;
console.log("连接已断开: " + new Date());
console.log(event);
},
// 发生错误
SOCKET_ONERROR(state, event) {
console.error(state, event);
},
// 收到服务端发送的消息
SOCKET_ONMESSAGE(state, message) {
state.socket.message = message;
},
// 自动重连
SOCKET_RECONNECT(state, count) {
console.info("消息系统重连中...", state, count);
},
// 重连错误
SOCKET_RECONNECT_ERROR(state) {
state.socket.reconnectError = true;
}
}
});
3.要websocket使用的页面
插件暴露的函数
send 发送非json类型的数据(使用插件时不能启用JSON消息传递)
sendObj 发送json类型的数据(必须在使用插件时启用JSON消息传递)
$connect 连接websocket服务器(必须在使用插件时启用手动管理连接选项)
onmessage 收到服务端推送消息时的监听
$disconnect 断开websocket连接
移除消息监听
delete proxy.$socket.onmessage
<script setup>
import { onMounted, getCurrentInstance } from "vue";
const { proxy } = getCurrentInstance();
onMounted(()=>{
proxy.$disconnect();//断开连接
proxy.$connect(`你的websocket服务端连接地址`);//连接websocket
//收消息
proxy.$socket.onmessage = res => {
// console.log(res, "我收到的消息");
};
// 调用send方法,以字符串形式发送数据
proxy.$socket.send('some data');
// 如果fomat配置为了json,即可调用sendObj方法来发送数据
proxy.$socket.sendObj({ msg: 'data'} );
})
</script>
二、启用Piain集成
1.在mian.js中
import { useSocketStoreWithOut } from "/@/store/useSocketStore";
import VueNativeSock from "vue-native-websocket-vue3";
const piniaSocketStore = useSocketStoreWithOut(app);
app.use(VueNativeSock, `你的websocket服务端连接地址`, {
// 启用pinia集成 | enable pinia integration
store: piniaSocketStore,
// 数据发送/接收使用使用json
format: "json",
// 开启手动调用 connect() 连接服务器
connectManually: true,
// 开启自动重连
reconnection: true,
// 尝试重连的次数
reconnectionAttempts: 5,
// 重连间隔时间
reconnectionDelay: 3000
});
2.根目录下创建store文件夹,分别创建PiniaType.ts,store.ts,useSocketStore.ts文件
①.PiniaType.ts文件
export type SocketStore = {
// 连接状态
isConnected: boolean;
// 消息内容
message: string;
// 重新连接错误
reconnectError: boolean;
// 心跳消息发送时间
heartBeatInterval: number;
// 心跳定时器
heartBeatTimer: number;
};
export type socketType = {
$connect: () => void;
};
②.store.ts文件
import { createPinia } from "pinia";
import { App } from "vue";
const store = createPinia();
export function setupStore(app: App<Element>) {
app.use(store);
}
export { store };
③.useSocketStore.ts文件
import { App } from "vue";
import { defineStore } from "pinia";
import { setupStore } from "./store";
import { SocketStore } from "./PiniaType";
export const useSocketStore = (app: App<Element>) => {
return defineStore({
id: "socket",
state: (): SocketStore => ({
// 连接状态
isConnected: false,
// 消息内容
message: "",
// 重新连接错误
reconnectError: false,
// 心跳消息发送时间
heartBeatInterval: 50000,
// 心跳定时器
heartBeatTimer: 0
}),
actions: {
// 连接打开
SOCKET_ONOPEN(event: any) {
console.log("successful websocket connection");
app.config.globalProperties.$socket = event.currentTarget;
this.isConnected = true;
// 连接成功时启动定时发送心跳消息,避免被服务器断开连接
this.heartBeatTimer = window.setInterval(() => {
const message = "心跳消息";
this.isConnected &&
app.config.globalProperties.$socket.sendObj({
code: 200,
msg: message
});
}, this.heartBeatInterval);
},
// 连接关闭
SOCKET_ONCLOSE(event: any) {
this.isConnected = false;
// 连接关闭时停掉心跳消息
window.clearInterval(this.heartBeatTimer);
this.heartBeatTimer = 0;
console.log("连接已断开: " + new Date());
console.log(event);
},
// 发生错误
SOCKET_ONERROR(event: any) {
console.error(event);
},
// 收到服务端发送的消息
SOCKET_ONMESSAGE(message: any) {
this.message = message;
},
// 自动重连
SOCKET_RECONNECT(count: any) {
console.info("消息系统重连中...", count);
},
// 重连错误
SOCKET_RECONNECT_ERROR() {
this.reconnectError = true;
}
}
})();
};
// Need to be used outside the setup
export function useSocketStoreWithOut(app: App<Element>) {
setupStore(app);
return useSocketStore(app);
}
3.要websocket使用的页面
插件暴露的函数
send 发送非json类型的数据(使用插件时不能启用JSON消息传递)
sendObj 发送json类型的数据(必须在使用插件时启用JSON消息传递)
$connect 连接websocket服务器(必须在使用插件时启用手动管理连接选项)
onmessage 收到服务端推送消息时的监听
$disconnect 断开websocket连接
移除消息监听
delete proxy.$socket.onmessage
<script setup>
import { onMounted, getCurrentInstance } from "vue";
const { proxy } = getCurrentInstance();
onMounted(()=>{
proxy.$disconnect();//断开连接
proxy.$connect(`你的websocket服务端连接地址`);//连接websocket
//收消息
proxy.$socket.onmessage = res => {
// console.log(res, "我收到的消息");
};
// 调用send方法,以字符串形式发送数据
proxy.$socket.send('some data');
// 如果fomat配置为了json,即可调用sendObj方法来发送数据
proxy.$socket.sendObj({ msg: 'data'} );
})
</script>