1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- import $store from "@/store";
- import {
- VUE_APP_WS_URL
- } from "@/utils/index.js";
- const Socket = function() {
- let url = VUE_APP_WS_URL
- this.ws = new WebSocket(wss(url));
- this.ws.onopen = this.onOpen.bind(this);
- this.ws.onerror = this.onError.bind(this);
- this.ws.onmessage = this.onMessage.bind(this);
- this.ws.onclose = this.onClose.bind(this);
- };
- function wss(wsSocketUrl) {
- let ishttps = document.location.protocol == 'https:';
- if (ishttps) {
- return wsSocketUrl.replace('ws:', 'wss:');
- } else {
- return wsSocketUrl.replace('wss:', 'ws:');
- }
- }
- Socket.prototype = {
- vm(vm) {
- this.vm = vm;
- },
- close() {
- clearInterval(this.timer);
- this.ws.close();
- },
- onOpen() {
- this.init();
- console.log('创建连接了!')
-
- this.send({
- type: "login",
- data: $store.state.app.token
- });
- this.vm.$emit("socket_open");
- },
- init() {
- var that = this;
- this.timer = setInterval(()=> {
- that.send({
- type: "ping"
- });
- }, 10000);
- },
- send(data) {
- return this.ws.send(JSON.stringify(data));
- },
- onMessage(res) {
- const {
- type,
- data = {}
- } = JSON.parse(res.data);
- this.vm.$emit(type, data);
- },
- onClose: function() {
- clearInterval(this.timer);
- },
- onError: function(e) {
- this.vm.$emit("socket_error", e);
- }
- };
- Socket.prototype.constructor = Socket;
- export default Socket;
|