前两天群里有兄弟在吐槽,作远程推送的时候:老板要求APP桌面图标的右上角显示红色未读数字(数字角标)要精准,有多少未读通知就显示数字几;可是后台的弟兄在发送推送通知的时候,每次的角标是1,而后要移动端这边本身去把这个未读数字去累加,而后显示在APP上;而且后台很是执拗的认为这个累加未读消息数量是在移动端处理的..... 微信
这就尴尬了,碰到执拗的队友,沟通不成的时候确实是很痛苦的!app
这里我说说本身在作推送功能时候的这个角标的验证过程和理解,给后面的为碰到相似状况的同窗一些参考。测试
随便截个图举个例子看看spa
当APP是处于后台的时候,实现这个仍是好说的,由于当推送通知到达的时候是能够监听到的,能够获取到推送信息里面的角标数字而后进行累加。code
可是当APP完成退出后台的时候,想要app监听到通知而且读取通知信息设置角标,这个好像是办不到的!blog
后台推送消息的格式按照苹果官方提供的格式,大体是这样:it
{ "aps" : { "alert" : { "title" : "Game Request", "body" : "Bob wants to play poker", "action-loc-key" : "PLAY" }, "badge" : 5 }, "acme1" : "bar", "acme2" : [ "bang", "whiz" ] }
“aps”格式是固定的,后面的"acme1", "acme2”是自定义的数据。其中“badge"就是app的角标数字io
因此要证明APP的桌面红色角标(未读消息数字)究竟是由后台控制的仍是移动端本身控制的,这个很容易。百度地图
让app内部不要本身操做角标变化,或者把该app彻底退出,而后后台开始推送,假设推送的消息badge是数字几,并且app的角标也是显示数字几,class
这个就足以证实app的红色角标是由后台推送时候控制的了!
固然话说回来,想要实现对app这个角标的精准显示,须要一个强大的后台:对每一个会员在app的读取未读消息进行追踪记录上报,
而后下次推送的时候,对每一个会员要进行未读消息的统计,而后在推送消息里面设置精准的badge数字。就能作到app精准的显示未读消息数字了。
咱们看好比QQ,微信等app,它们的角标数字是作的很是精准的,人家的后台之强大,那是没得比的。
可是咱们通常的APP, 你也想作到角标精准?有必要吗?你连作推送都是用了第三方的推送sdk如极光、个推,你还想作到精准显示角标,你去看看极光和个推对于群推的方法,
压根都没提供精准设置badge的位置,说明想实现精准实现角标,专门研究推送的这些第三方公司也以为难度很大,或者说要付出很大的代价!
通常来讲,大多数app的角标数字作的是意思意思,没那个精准,我测试过的有百度地图、简书、新浪财经等等,app的角标显示也没有作什么精准显示。因此对于我们作的若是是一个普通的app, 角标数字的显示也就意思意思就好了,主要是为了提醒用户你有未读消息嘛!真的想作到精准显示角标,那就要和后台的兄弟谈好,让他们作好准备加油开干把!