状态流程图可以使需求的表达更加直观和高效!那么,产品经理是如何绘制状态流程图的呢?
当我第一次进入银行时,我设计了一个优惠券产品方案对“优惠券使用逻辑”的要求描述如下:
当用户支付订单时,选择一个优惠券,并且在支付被取消之前不允许其他订单使用优惠券;如果用户支付成功,订单使用的优惠券将进入使用列表;如果用户未能支付或取消支付,则该订单使用的优惠券被释放,其他订单可以继续使用该优惠券;如果用户长时间不支付,导致优惠券到期,则优惠券不能再使用,并且用户或者重新选择可用的优惠券或者不使用优惠券;如果在订单成功支付后发生退款,订单使用的优惠券将失效且不能再使用,进入无效优惠券列表。如果优惠券过期,优惠券会进入过期优惠券列表的需求描述认为自己非常清楚和完整。然而,当审查开发需求时,他们说他们不理解这些需求,并且反馈需求信息太多,无法在短时间内消化。
但是由于我准备不足,场面非常尴尬。最后,会议不得不提前结束。
显然有自己清晰的逻辑,为什么开发人员还不明白?你的表达不够清楚吗?还是发展故意让我为难?
我一直找不到解决办法。最后,在同事的建议下,我画了一个状态流程图:
。我拿着这个状态流程图,再次告诉开发人员需求,并在半小时内通过了需求评审。
状态流程图解决了什么问题?回头看优惠券需求的书面描述,我相信大多数人暂时不会理解这个线索。我不知道这些状态从哪里开始,也不知道有多少个状态,更不知道这些状态是如何转换的。
人脑天生对图形信息更敏感,图形的表现力远远大于文字。这也是为什么从图画演变而来的象形文字是人类祖先发明的第一个字符的一个重要原因。
,在状态流程图中,每个节点代表一个状态值,带箭头的行代表状态的流向,行上的文本代表状态流的条件状态流程图是复杂逻辑的“象形图”。这次
的经历让我明白,一个50字的状态流程图可以直观清晰地表达出原来近300字的文字描述,开发也更容易理解。
的效率提高明显。
有了这个状态流程图,无论我们自己理解业务还是用开发来解释需求,都可以事半功倍。
状态流程图,使需求表达更加直观高效!
如何绘制状态流程图?状态流程图的绘制方法其实很简单让我们以优惠券状态为例来说明如何绘制状态流程图。
因为状态流图是为了直观地解释业务,所以当我们绘制状态流图时,我们必须从业务出发,根据业务需求定义状态值
基于对业务的理解,我们定义了优惠券的四种状态:
待使用:优惠券的默认状态,所有收到的优惠券都处于默认使用状态;冻结:由于支付中可能出现的问题,为了防止使用过的优惠券回滚到待定使用(不合逻辑),我们定义了一个中间状态根据支付结果,决定如何转移优惠券状态;已用:已成功使用的优惠券可能因退款而失效。过期:用于标记过期优惠券或因退款而过期的优惠券。当定义状态值时,还需要注意以下两点:
简化不必要的状态状态越多,逻辑就越复杂。不必要的状态也会增加用户的认知成本,对业务没有帮助。定义的状态值必须互斥不允许包含关系和交叉关系。否则,业务逻辑无法准确描述定义了有限数量的必要互斥状态值,这是绘制状态流程图的关键步骤。
步骤2:阐明状态值的转换关系和条件定义状态值后,我们需要阐明所有状态之间的转换关系和条件
所谓切换关系和条件是指:从当前状态切换到另一个状态需要满足哪些条件
分析优惠券使用的状态切换关系和条件如下:
当用户支付订单时,优惠券被选择并切换到“冻结”状态;如果用户支付成功,订单使用的优惠券将切换到“已使用”状态;如果用户未能支付或取消支付,订单使用的优惠券将切换为“待使用”;如果用户长时间不付款,导致优惠券过期,订单中使用的优惠券将切换到“过期”状态,用户只能重新选择可用的优惠券。如果在成功支付订单后发生退款,订单使用的优惠券将切换到“过期”状态;如果优惠券在到期前未被使用,优惠券会切换到“到期”状态。在某些业务场景中,当一种状态切换到另一种状态时,会出现多种情况有些只能在同时满足多个条件时切换,有些只能在满足多个条件时切换。当结合开关条件时,有必要明确区分
步骤3:映射将上述过程映射到一个映射中:
状态流程图通过三个简单的步骤完成
是一个状态流程图,可以直观有效地表达优惠券使用的复杂逻辑。
和业务流程图有什么异同?状态流程图与业务流程图相同,两者都是为了更好地表达需求和提高通信效率。但是,两者之间有一个很大的区别:
关注点不同:状态流程图更关注状态的变化,业务流程图更关注业务操作的过程;目的是不同的:状态流程图是为了便于理解同一事物的不同形式以及转换关系和条件,而业务流程图是为了便于理解业务发展过程;图的节点是不同的:状态流程图的节点是状态值,业务流程图的节点是动作;状态流程图更宏观,业务流程图强调更多细节。
从某种角度来看,状态流程图是一种特殊的业务流程图,它是为同一事物的不同状态和状态之间的行为转换而构建的
总结状态流程图的绘制也是一个熟能生巧的过程。在基础阶段,建议每个人绘制尽可能多的状态流程图。
是一个很好的状态流程图,它能更直观地描述需求,是产品方案设计中一个非常有效的表达工具。
这篇文章最初由@ shibo发布。每个人都是产品经理。未经作者许可,禁止重印。
张地图来自Unsplash,基于CC0协议