vue建立socket长连接

getSocket() {
      //获取消息
      var socket = new WebSocket('wss://你的socket地址');
      socket.onopen = function () {
        const _this = this
        var userInfo = JSON.parse(localStorage.getItem('userInfo'))//用户的登录信息
        if (userInfo) {
            var login_data = { type: 'init', id: userInfo.id}
//这里是传参,具体的传参与后台进行沟通
            login_data = JSON.stringify(login_data)
            socket.send(login_data)
            console.log("websocket握手成功!")
        }
    }
      let _this = this;
      socket.onmessage = function(e) {
        try {
          let data = JSON.parse(e.data);
          switch (data.message_type) {
            case "init":
              console.log(data.id + "登录成功");
              break;
            case "system_msg":
              _this.$store.commit("getsystemMsgList", data);
              break;
            case "shop_certification_result":
              _this.$store.state.systemMsgList.msg.unshift(data.msg);
              _this.$store.commit(
                "getsystemMsgList",
                _this.$store.state.systemMsgList
              );
              break;
            case "now_msg":
              _this.$store.state.systemMsgList.msg.unshift(data.msg);
              _this.$store.commit(
                "getsystemMsgList",
                _this.$store.state.systemMsgList
              );
              break;
          }
        } catch (err) {
          console.log(err);
        }
      };
    }

这个方法定义在app.vue的methods里面,在created里面当用户的Token存在时调用。其中的传参可以与后台进行沟通后进行传参。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值