【uniapp】uniapp的安卓apk图标角标设置消息数量

1、主要方法:

设置角标:

plus.runtime.setBadgeNumber(999)

清除角标:

//plus.runtime.setBadgeNumber(0)//没有效果

plus.runtime.setBadgeNumber(-1) //有效果

2、使用在具体的生命周期

1、打开app获取角标数量

2、关闭app获取角标数量

3、非登入和退出登入获取角标数量

在App.vue中:

html 复制代码
<script>
	export default {
		onLaunch: function() {
			console.warn('当前组件仅支持 uni_modules 目录结构 ,请升级 HBuilderX 到 3.1.0 版本以上!')
			console.log('App Launch')
			// #ifdef APP-PLUS
			// #endif 
		},
		onShow: function() {
			console.log('App Show')
			// #ifdef APP-PLUS
				this.getList();
			// #endif 
		},
		onHide: function() {
			console.log('App Hide')
			// #ifdef APP-PLUS
				this.getList();
			// #endif 
		},
		methods:{
			getList() {
				const token = uni.getStorageSync('token') || false
				//是否在登入状态(看自己代码检测登入状态的判断方式)
				if (uni.getStorageSync('token') && token) {
					let Info = uni.getStorageSync('userInfo')
					let obj = {
						noticeUser: Info.userId,
					}
					//获取当前账号接收的未读消息数量(角标要展示的数量)
					this.request({
						url: '/message/listCount',
						method: 'get',
						params: obj
					}).then(res => {
						this.list = res.data
						let num = 0
						res.data.forEach(item => {
							num += item.num
						})
						if(num>0){
							this.setBadge(num)
						}else{
							this.clearBadge()
						}
					}).catch(error => {
						this.clearBadge()
						console.log('失败', error);
					})
				}else{
				   //未登入状态清空
					this.clearBadge()
				}
			},
			//设置角标
			setBadge(num){
				plus.runtime.setBadgeNumber(num)
			},
			//清除角标
			clearBadge(){
				plus.runtime.setBadgeNumber(-1)
			}
			
		}
	}
</script>
<style>
	.container {
		width: 100vw;
		height: 86.5vh;
	}
</style>

3、注意事项

1、记得加上一下内容,限制在app中生效,不然在网页测试会plus报错

html 复制代码
// #ifdef APP-PLUS
// #endif 

2、打包发布后根据提示去uniapp官网按流程处理相关配置就行

3、非外网使用1.0版本就行

4、清除角标plus.runtime.setBadgeNumber(0)不生效,因此我采用了传-1

相关推荐
豹哥学前端1 小时前
事件循环(Event Loop)深度解析:让你彻底搞懂 JS 的执行顺序
前端·javascript·面试
竹林8181 小时前
用 wagmi v2 + Next.js 14 搞 NFT 交易市场前端:从合约调用失败到顺利上架,我踩了哪些坑
javascript·next.js
前端不开发1 小时前
用一个 Bookmarklet(书签脚本),给任意网页挂一个可拖拽悬浮窗
前端·javascript
接着奏乐接着舞1 小时前
【无标题】
开发语言·前端·javascript
雨雨雨雨雨别下啦1 小时前
心理健康AI助手 - 项目总结
前端·javascript·vue.js·人工智能·信息可视化
风之舞_yjf2 小时前
Vue基础(32)_TodoList案例
前端·javascript·vue.js
音视频牛哥2 小时前
大牛直播SDK(SmartMediaKit)Android平台Unity3D RTSP/RTMP播放器集成实践
android·unity3d·rtsp播放器·rtmp播放器·unity3d rtmp播放器·安卓unity rtsp播放器·安卓unity rtmp播放器
w1wi2 小时前
安卓抓包完全指南(一):从入门到 SSL Pinning 绕过
android·网络协议·ssl
Amos_Web3 小时前
Rspack 源码解析 (2) —— 从 rspack build 到输出 dist,完整编译链路详解
前端·javascript