vue建立socket长连接
getSocket() {//获取消息var socket = new WebSocket('wss://你的socket地址');socket.onopen = function () {const _this = thisvar userInfo = JSON.parse(localStorage.getItem(...
·
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存在时调用。其中的传参可以与后台进行沟通后进行传参。
更多推荐
已为社区贡献3条内容
所有评论(0)