uniapp使用websocket长连接,接收消息通知

1.在onload周期里进行连接

onLoad(){
    //websocket连接
	this.webSocketConfig()
}

methods:{
        //建立socekt链接
		  webSocketConfig(){
		  this.reconnectTimer && clearTimeout(this.reconnectTimer)
		  this.interVal && clearInterval(this.interVal)
		  var that = this
		  var socketOpen = false;
		  
		  this.socketTaskChat = uni.connectSocket({
			  url: this.websocketUrl + piniaData.userInfo.id,
			  data(){return {}},
			  header:{'content-type': 'application/json'},
			  method: 'GET',
			  success: res =>{

			  },
			  fail: () =>{

			  },
			  complete: () =>{

			  }
			});
		  this.socketTaskChat.onError(function(res){
            //连接失败,进行重连
			that.handleHeart()
		  });

		this.socketTaskChat.onClose(function(res){

		});
		this.socketTaskChat.onOpen(function(res){
		  this.reconnectTimer && clearTimeout(this.reconnectTimer)
		  this.interVal && clearInterval(this.interVal)
		});
		  this.socketTaskChat.onMessage(function(res){
			//接收到消息
			//可以触发vuex中的网络请求,然后在需要接收消息通知的页面里使用vuex中的state数据

            let data = JSON.parse(res.data)
            if(data.type == 'a'){
                //触发vuex中的addA方法, 修改vuex中state中的a
                store.commit('addA')
            }else if(data.type == 'b'){
                //触发vuex中的addB方法, 修改vuex中state中的b
                store.commit('addB')
            }
		  });
		},
		//心跳检测
		handleHeart() {
			var that = this
			this.interVal = setInterval(function() {
				that.handleSend()
			}, 5 * 1000)
		},
		//发送消息
		handleSend() {
			var that = this
			var data = {
				state: 1,
				method: 'heartbeat'
			}
			this.socketTaskChat.send({
				data: data,
				success(res) {
                    clearInterval(that.interVal)
                },
				fail(res) {
					that.reconnect()
				}
			});
		},
		// 重新连接socket
		reconnect() {
			var that = this
			clearTimeout(this.reconnectTimer)
			clearInterval(this.interVal)
			this.reconnectTimer = setTimeout(() => {
				that.webSocketConfig()
			}, 5 * 1000)
		},
}

2.为了演示,只是写一个简易版的vuex

import { createStore } from "vuex"

export default createStore(({
	state: {
		a: 0,
        b: 0
	},
	mutations: {
		addA(state){
			state.a++
		},
        addB(store){
            state.b++
        }
	}
}))

3.在页面A中监听vuex中的A, B页面中监听vuex中的B

监听到改变了,直接调接口更新页面数据

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
uniapp是一种跨平台的开发框架,可以用于开发手机应用程序。为了实现全局消息推送提示功能,可以结合vuex和websocket技术。 首先,我们可以使用vuex来管理应用程序的状态。vuex是一种专门用于Vue.js开发的状态管理模式,它可以将组件之间共享的状态集中管理,并且可以实现数据的响应式更新。 在vuex中,我们可以创建一个全局的消息状态,包括未读消息的数量和消息列表。当收到新的消息时,可以通过vuex的方法来更新这些状态。组件可以通过vuex的计算属性或者方法来获取当前的未读消息数量和消息列表。 接下来,我们可以使用websocket来实现实时的消息推送功能。websocket是一种在客户端和服务器之间进行双向通信的协议,它可以实现实时的数据传输。 在uniapp中,我们可以使用uni-app-plus插件来支持websocket使用。可以在应用程序的入口文件中创建一个websocket连接,并且监听消息的入站事件。当收到新的消息时,可以通过websocket发送一个vuex的mutation来更新消息状态。 在组件中,可以监听vuex中消息状态的变化,并且在有新消息到达时显示一个推送提示。可以使用uni-app的原生弹框组件或者自定义样式来实现这个推送提示。 总结起来,使用uniapp开发手机app,结合vuex和websocket可以实现全局消息推送提示功能。通过vuex管理应用程序的状态,通过websocket实现实时的消息传输,结合组件的监听和显示,实现全局消息推送提示的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值