zoukankan      html  css  js  c++  java
  • Java生鲜电商平台-生鲜电商中消息系统的设计与架构实战(小程序/APP)

    Java生鲜电商平台-生鲜电商中消息系统的设计与架构实战(小程序/APP)

    说明: 在任何一个生鲜电商小程序或者APP中,消息系统都是一个必不可少的功能模块,其核心目的是让产品直接与用户产生交互,帮助用户更容易获得提醒,在保证用户体验的同时可

    有效提升用户留存和活跃。那么,消息系统在设计的有哪些需要注意的点呢?

    一、生鲜电商消息分类

    在进行消息系统设计时,我们需要先把产品可能涉及的消息进行分类,确定不同消息的实际触发场景和节点,以下是几种常见的消息类别。

    1. 互动消息

    常见于社区类产品,包括点赞、评论、转发、分享和打赏等互动行为,由用户A基于用户B生产的相应内容(如动态、文章、视频等)执行互动操作后触发生成。

    2. 关注消息/好友申请

    常见于社区和社交类产品,其触发形式主要根据实际的产品形态进行确定,如用户关系为强关系,则可将消息的触发设计为实时触发;而如果为弱关系,则可以考虑将触发逻辑设计为定时或定量触发。

    3. 订单、物流消息

    在交易类产品上比较多见,主要根据相关订单和物流状态的变更而触发提醒。同时,需要注意区分状态变更时的用户状态和提醒必要性,对于用户主动触发(即显性)的状态变更可考虑不做提醒,记录类的消息除外。

    4. IM聊天消息

    有社交属性产品的基础功能,主要可以分为一对一陌生人和好友聊天,以及单聊和群聊;消息的触发为发送后实时到达并提醒,以保证聊天过程顺畅。

    5. 内容、活动和系统通知

    类似于IM聊天消息,但展现形态和触发场景更灵活多变,可根据设定条件或后台人工触发,跟产品基础调性和内容的相关性极高。

    二、时间戳

    对于消息的显示,可根据所要提醒内容的格式和优先级进行设计,但无论如何设计,消息时间戳都是组成一条消息不可或缺的部分。其中,使用12或24小时制一般以用户设备选定的格式为标准,常见的时间戳设计规则如下。

    1. 互动、订单、物流类消息时间戳

    以用户设备的时间为参考:

    ①消息在今天范围内,显示XX:XX,如 10:02, 18:10

    ②消息在昨天范围内,显示昨天XX:XX,如昨天10:02,昨天18:10

    ③消息在昨天前且在今年内,显示 XX-XXXX:XX,如4-12 10:02,5-4 18:10,12-2012:12

    ④消息在今年以前,显示XX-XX-XX XX:XX,如16-4-12 10:02,17-12-1 12:12

    2. IM聊天消息时间戳

    a)以用户设备的时间为参考:

    ①消息在今天范围内,显示XX:XX,如 10:02, 18:10

    ②消息在昨天范围内,显示昨天XX:XX,如昨天10:02,昨天18:10

    ③消息在昨天前且在今年内,显示 XX-XXXX:XX,如4-12 10:02,5-4 18:10,12-20 12:12

    ④消息在今年以前,显示XX-XX-XX XX:XX,如16-4-12 10:02,17-12-1 12:12

    b)聊天会话页消息流的时间戳显示与隐藏:

    ①新消息接收或发送的时间相对于已经显示的时间戳,小于5分钟的,消息不显示时间戳;

    ②大于或等于5分钟的,显示时间戳。

    三、可见对象

    消息可见对象可理解为提醒对象,但两者并不完成对等,因为对同一条消息而言,对于不同可见对象的提醒方式并不完全一样。

    1. 目标对象可见

    如关注、订单、物流和系统通知类消息,消息有明确的目标对象(即被关注对象、下单用户和通知对象),该消息的指向为明确指向。

    2. 目标对象和内容主可见

    如互动类型的消息,内容主生产的内容下可能有多个用户参与互动,且互动的明确对象不一定为内容主(内容主为内容关联互动对象),此时产生的消息提醒就涉及到目标对象和内容主可见。

    3. 会话对象可见

    见于IM聊天模块,单聊为聊天双方可见,群聊为群成员可见,但对于聊天系统提示类的消息,则需要根据提示的具体场景来确定可见性(如微信群组退群消息仅群组可见,安全风险提示仅消息接收方可见等)。

    四、提醒方式

    1. 应用内

    a)红点:可分成不计数红点的弱提醒,以及计数(超过99显示99+)红点的强提醒;同时,进一步细分还可以增加类红点方式提醒(可参考QQ群的免打扰提醒方式),该方式比不计数红点提醒更弱,仅用来表示计数,强化用户感知。

    b)震动和声音:一般仅针对计数红点的强提醒消息进行震动和声音响应,同时,需要对震动和声音响应进行频率限制,如1秒内收到多个消息,仅震动和声音响应一次。

    2. 应用外

    a)APP红点:根据应用内消息计数来标记红点进行提醒。

    b)推送:当APP处于后台(即在屏幕中APP为不可见状态)时才使用推送提醒,由于Android和iOS机制不同,此处区分两个平台讲解;

    ①Android:设备要接收到推送需保证APP进程存活,而国内Android设备的系统均为定制过的ROM,APP存活需将APP设置为白名单(如微信钉钉跟各大手机厂商均有合作添加产品白名单,或将APP加入手机自带的安全工具白名单),这样才能保证推送不会丢失;另外,国外版的Android大多为原生系统,进程存活率较高,不需要额外设置白名单来保证存活。

    ②iOS:iOS的推送均需要通过苹果官方服务器进行推送,跟进程存活没有关系,无论进程在后台活跃还是被kill,都能收到推送(前提是用户开启推送通知权限,可参考小红书的常驻引导开启方式)。

    c)短信:到达率和成本更高,一般仅用于交易、大型推广活动和用户召回等强提醒场景;同时,当用户推送权限处于关闭状态时,也可使用短信触达后引导开启。

    3. 补充

    对于有多端(不同设备)登录功能的产品,还需要设计相应的多设备登录时,移动设备可开启免提醒的功能(具体可参考微信和钉钉)。

     
     

    五、写在最后

            消息系统的设计,要充分考虑产品所针对的用户群体,保持消息频率的克制和消息的实际意义,而非为了点击转化的诱导提醒。当然,理想和现实总是不一样的,用户体验和产品效益之间永远都是一个聊不完的话题,最重要的还是找到那个平衡点。只有这样,消息系统才能真正的起到促进用户留存和活跃的作用

     

    总结:做互联网应用,无论是生鲜小程序还是APP,目的是为了留住与激活用户,形成用户购买力,提高满意度,最终达成交易的,当然本文只是抛砖引玉,希望本文可以给大家一点思考与建议。

    共同学习QQ群:793305035

     
  • 相关阅读:
    数学形态学——腐蚀、膨胀、开、闭、细化
    VS2010中 报错:error C2146、error C4430 原因一:缺少CvvImage类
    帧同步和状态同步
    HTML5触摸事件演化tap事件
    screenX clientX pageX的区别
    phaser的小游戏的onInputDown问题
    phaser入手
    pixi.js 微信小游戏 入手
    正则表达式
    剖析Vue原理&实现双向绑定MVVM-2
  • 原文地址:https://www.cnblogs.com/jurendage/p/12929120.html
Copyright © 2011-2022 走看看