vue使用websoket

参考链接:https://www.cnblogs.com/qisi007/p/10213886.html

export default {
    name: "realdetail",
    components: {},
    data() {
      return {
        wsuri: null,
        websock: null
      }
      };
    },
    created() {
        this.wsuri = "ws://127.0.0.1:8210";//监听地址
        this.initWebSocket();
    },
    destroyed() {
      this.websock.close() //离开路由之后断开websocket连接
    },
 methods: {initWebSocket() { //初始化weosocket
        this.websock = new WebSocket(this.wsuri);
        this.websock.onmessage = this.websocketonmessage;
        this.websock.onopen = this.websocketonopen;
        this.websock.onerror = this.websocketonerror;
        this.websock.onclose = this.websocketclose;
      },
      websocketonopen() { //连接建立之后执行send方法发送数据
        let message = {
          type: "login",
          data: {"mn":this.deviceInfo.mn}
        };
        console.log(message);
        this.websocketsend(JSON.stringify(message));
      },
      websocketonerror() { //连接建立失败重连
        this.initWebSocket();
      },
      websocketonmessage(e) { //数据接收
        const redata = JSON.parse(e.data);      console.log(redata)
        this.handlerData(redata);
        this.$forceUpdate(); // 强制刷新一下数据
      },
      websocketsend(Data) { //数据发送
        this.websock.send(Data);
      },
      websocketclose(e) { //关闭
        console.log('断开连接', e);
      },
      handlerData(data) {
        if (data.type) {
          switch (data.type) {
            case "realData":
              this.updateRealData(data.data);
              this.deviceInfo.onlineStatus=1;
              break;
            case "online":
              this.deviceInfo.onlineStatus=1;
              break;
            case "offline":
              this.deviceInfo.onlineStatus=0;
              break;
          }
        }
      },
      //更新实时数据
      updateRealData(data){
        this.realData=this.handleRealData(data);
      }
    }

  在线测试websocket:http://coolaf.com/tool/chattest

posted on 2021-09-16 10:23  七七2020  阅读(149)  评论(0编辑  收藏  举报

导航