12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- import $store from "@/store";
- import { VUE_APP_WS_URL } from "@/utils/index.js";
- import { mapState } from 'vuex';
- const Socket = function() {
- this.ws = new WebSocket(wss(VUE_APP_WS_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:');
- }
- }
- let token = uni.getStorageSync('token');
- Socket.prototype = {
- vm(vm) {
- this.vm = vm;
- },
- close() {
- clearInterval(this.timer);
- this.ws.close();
- },
- onOpen: function() {
- console.log("ws open");
- this.init();
- this.send({
- type: "login",
- data: token
- });
- this.vm.$emit("socket_open");
- },
- init: function() {
- var that = this;
- this.timer = setInterval(function() {
- that.send({ type: "ping" });
- }, 10000);
- },
- send: function(data) {
- return this.ws.send(JSON.stringify(data));
- },
- onMessage: function(res) {
- const { type, data = {} } = JSON.parse(res.data);
- this.vm.$emit(type, data);
- },
- onClose: function() {
- clearInterval(this.timer);
- },
- onError: function(e) {
- console.log(e);
- this.vm.$emit("socket_error", e);
- }
- };
- Socket.prototype.constructor = Socket;
- export default Socket;
|