uni-app快速入手 ——(11)uni-app如何简单快速使用websocket

14 篇文章 2 订阅

第一步创建一个websocket.js 

import variable from './variable.js'//ws长连接...

var connect = function(userId) {
	uni.connectSocket({
		url: variable.socketUrl + userId
	});
	uni.onSocketOpen(function(res) {
		console.log('WebSocket连接已打开!');
	});
	uni.onSocketError(function(res) {
		console.log('WebSocket连接打开失败,请检查!');
	});
	uni.onSocketMessage(function (res) {
	  console.log('收到服务器内容:' + res.data);
        
//监听推送消息作出对应响应
	  let noticeType = JSON.parse(res.data).noticeType
	  if(noticeType == 'message_change'){
		   uni.$emit('has-new-masg')
	  }else if(noticeType == 'bd_rescue_alarm'){
		  uni.$emit('sos-pop-alarm',{
			  alarms:JSON.parse(res.data).noticeInfo
		  })
	  }
	});
	uni.onSocketClose(function (res) {
	  console.log('WebSocket 已关闭!');
//监听断开重连
	  uni.$emit('websocket-close')
	});
}

var closeSocket = function(){
	 uni.closeSocket();
}

module.exports = {
	connectSocket:connect,
	closeSocket:closeSocket
}

在index.vue中使用

import socket from '@/utils/websocket.js'

 

onLoad() {
			let that = this;

			if (that.hasLogin) {
				console.log("用户信息-------------", that.userInfo)
				// 连接socket
				socket.connectSocket(that.userInfo.openid)
				uni.$on('websocket-close', res => {
					console.log("websoket连接断开重新连接", res)
					socket.connectSocket(that.userInfo.openid)
				})
			}

			uni.$on('has-new-masg', res => {
				console.log("websoket已经连接推送======消息推送")
				
			})
			// sos求救推送
			uni.$on('sos-pop-alarm', res => {
				console.log("websoket已经连接推送======消息推送", res.alarms)
				
			})
			
			

		},

简单的socket就可以了

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

随便起的名字也被占用

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值