|
产品需求是如何落地到原型设计的?本文将结合案例和大厂产品经理常用的方法论,通俗化讲解如何系统拆解产品需求,希望对你有所收获。$ n1 h; \! E% q* j* x* U( m# ~. c9 m8 ^
4 G4 p; m" j1 y+ ]$ n
3 C/ G1 ~0 U' p7 ]! h2 L! T, q3 n: W" x. K3 e
一、产品经理设计思路是什么样 n* N: j. ?9 u' }; D+ [; o Y5 m. T
面临新业务线拓展或者产品升级的时候,在收集到一大堆乱七八糟的需求后,你可能会想,我要怎么着手呢?答案是,搭框架找思路。
6 \' O- T2 R& \这是一个产品经理通用的设计思路框架,遵循由粗到细、自上而下的流程,具体如下:3 k# |1 G% g( K/ X
战略层—–业务目标是什么,即定方向,含用户、使用终端、市场竞争力和解决方案、项目计划;想清楚做什么,即把具备价值的需求进行梳理优先级排序包括形成产品初步架构& F! r0 m7 i+ q L7 Y, \
搭框架—–(功能和 DFX 非功能框架)难点在于梳理功能的全面和思路;dfx 需求:保证用户使用产品的安全、性能、可拓展等需求注:DFX 其实很重要但大部分都会被忽视,此文不做拓展、后续会通过一篇文章进行详细说明,(产品经理千万不能只盯住功能做产品)$ C) N: X: ]' j6 K) {# k
拆细节—–业务流程(重点梳理异常分支和外围数据交互)、业务操作、信息结构)
" y) }* r# s" M' i7 T% I* ]画界面—–交互设计、信息设计
: H; D7 T0 Q- y7 A以上的思路大家可以按需参考,本文着重讲解拆解 2 步骤的方法,即搭建初步功能框架,并可落地到原型指导设计。
5 G% V( S7 X# |0 f* U8 ^$ m 二、如何搭建功能框架呢?
9 A6 ]: Y2 ]1 X5 C注:搭功能框架也是从宽度上定义业务范围,而不是要深挖细节、要注意避免陷入思路混乱、把握好分寸、见好就收。0 D/ H( ?( f6 r0 k$ L
1. 用例驱动设计法(UDD)
3 w% T/ S& _- x* S0 n; U用例驱动设计是一种基于用户行为和需求来设计软件开发的方法,有步骤有层次梳理出系统功能的方法,可粗浅理解为用户故事,是一个通用的搭框架方法;如类似网购下单、酒店预定、银行贷款等场景;
2 a3 U7 L# J/ q2 I2 U& _9 u9 Q整体思路遵循:识别参与者使用场景及问题—–定义描述用例(目标层用例—步骤层用例— - 实现层用例)并简化) ~9 n; ^+ f3 |* c0 [7 ]
(1)识别使用场景及问题
0 |& t$ K3 \- x" `; r. ?& L首先,我们通过华为 IPD 需求管理思路那篇,知道产品需求 = 基于场景的解决方案,因此拿到一个产品需求,我们需要想清楚对应的场景,即 5w1h1e。: J u+ c8 a( O1 ]
who(面向对象)、why、when+where(场景)、what(干什么)、以及 how(怎么实现)、else(限前置和后置)( V# o/ T# t9 k1 J
比如要做一个访客预约系统,按照上面的描述方法,我们明白了系统的使用场景是这样:
) R: G8 m5 T8 W: g5 y! \2 O6 n一个基于外来访客,由于园区为了保障安全管理,在临时进入园区前,需要进行线上登记个人资料、并实名认证的产品,并且园区审核通过,验证身份才可以进入和离园。/ r+ X' V) K P. T
(2)拆分:目标层 - 步骤层 - 实现层0 j% E4 B9 b) `/ `
结合上面的例子:
8 x& S' v/ ?6 H3 @8 F访客进入园区就是目标层用例,为了实现这个整体目标,我们需要步骤层用例进行支撑,这时候就可以拆分为第一个大框架
" C. `# D- S/ q4 U具体为:
i; I0 H7 {' D, q7 P步骤 1:访客在系统上提前登记—–线上预约
7 B0 y0 S5 U6 U0 r" q' a1 X0 d- }步骤 2:访客填写登记资料—–填写表单5 C1 G$ J' H4 _- D+ t
步骤 3:园区通过系统审核资料并通知访客结果—–审核管理" g5 S5 P& F; {3 z
步骤 4:访客接收通知— - 消息提醒* p# T+ b0 r7 Y9 N, o+ Y
步骤 5:访客查看提交记录—–预约记录
$ m) Q5 `% ]5 G2 n步骤 6:访客获得许可进入园区—身份验证
4 M+ C5 D" g P& Y" k6 `步骤 7:访客离园确认—身份验证! m% X6 f" C$ e/ o7 W2 n+ p
那针对每一个步骤层、具体如何实现呢?按照这个思路,通过拆分形成实现层用例(也就是用什么方案实现)
! F6 A4 b) a6 T最终这个功能框架会形成这样、(注意把不同用户端分开保证用例全面)如图:0 F( v* ]6 k+ j% M
& d D% M' t+ f1 k0 g5 C7 T
, V5 y! |6 W F+ U1 Y
I. _3 p1 Y: u
当然这是初步框架,仅作部分举例说明,你们可以自行拓展,只要保证覆盖全部的用例就行。1 g3 e- d7 Z2 O! [0 B" h
在这里,我们要注意几点:
. ?7 p; I8 j% z5 t9 ?4 V在多种实现方案并存的情况下,如何权衡呢?; Z" G+ W' {/ R+ u' Z# l1 M% R
1、结合功能实现成本、第三方对接周期、客户需要、技术实现能力、外围的交互模块等多方面因素进行决策,选择一个较为合理的实现方案: I: g7 m+ b, p& u% Z9 y9 `
2、如上面的进出身份验证,给了 4 种方案,有通行扫码、临时卡、人脸识别、指纹、语音,包括我们常见的支付也可以多种路径实现,如现金支付、信用卡支付、微信支付等
+ n- x7 M2 h/ s/ L7 t: h6 V小结:( N% g; H% ^% G) V' K! ]
1、工具:建议用思维导图、或者用例图进行梳理# ^$ L5 R/ g/ E2 G: @. _. t
2、目标:是形成产品功能结构(含一级特性、二级特性、甚至三级特性)
5 w$ o8 l( o" U0 z7 \2 g8 K/ X3、适用项目:比较独立、小型或需要快速迭代和更新的项目,注重从用户的角度出发来描述系统的功能需求4 J9 g5 p! G6 I0 O! N+ ?- T' ^' r
4、特点:方便快捷、拓展性较差、易于理解协作,但难以适用复杂业务 k! |6 X5 S4 _
2. 流程驱动设计法(PDD)
" ?! x. i6 b- c适用于业务协作方较多,具备较复杂的业务层级及审核,更注重流程标准化管理的产品,如 CRM、ERP 系统、工单管理系统、采购系统、数据精细管理等。
& q7 I: J* @- D/ _0 d# J1 Y整体思路遵循:识别关键业务流程—–拆分目标层用例—–业务操作
( Y5 h/ O" Y6 r/ W6 y! o& Z' ?比如 CRM 系统的流程是有明显前后顺序的,且为了精准做好客户关系管理,标准化的流程非常重要。通常按照以下步骤进行操作:' [: v U, b$ B w3 v0 \0 e
1、客户档案创建和维护—–客户管理流程3 K8 L1 H/ R( j. ?
2、销售机会(Lead)创建和跟进——销售管理流程
# `0 V3 d& N! X! R7 l' n4 l% l! _3、市场活动的策划、执行和跟进—— - 市场活动管理流程$ @; f T Z& ]0 L! N4 Y
结合以上顺序流程,就很适合用 PDD 来搭框架,我们大概拆分出几个目标层,并进一步落地到具体的功能模块中。下面是一些可能包括的模块:/ R5 j8 q( t, k: t+ E4 N, d" A* x6 f
客户管理模块:
. |! Z, x" d( F) N; ta. 客户档案:创建、查看、编辑、删除客户资料;" Y/ F3 K! } H6 D1 M
b. 客户分类:对客户进行分组和标记,例如根据客户来源、优先级、交易状态等进行分类;
% r* H- J$ o% q! ?; I1 k' [# q! U& fc. 客户关系历史记录:记录客户与企业之间的活动历史,包括通话、邮件、漏斗进展等。; b+ N+ S4 Z% U" j6 y
销售管理模块:
+ H% |+ M" h# u# U* u" ?a. 销售机会(Leads):创建、跟进、评估及关闭销售机会,可以关联相关的客户信息;
1 Q6 R( q; m" L4 z9 Q. q; J' nb. 产品 / 服务信息:录入、查看、编辑和删除产品或服务信息;( c( y( w$ O; v9 E
c. 报价单 / 订单:创建、发送、听取意见、确认并完成报价和订单交付等流程;6 x ~: W5 O3 v; X& j
d. 合同信息:建立一个合同管理库存储合同信息,以追踪合同执行情况和收款计划。
* n0 _. H; h- Y! Y" y8 i5 G& O8 z市场活动管理:
; }# k* @- c" a( A; `' Y t1 K5 j: Fa. 活动策划:创建市场活动,定义主题,摘要、预算、时间表等参数;
( d. J7 e; g6 V/ [4 D: M# k5 Gb. 活动跟踪:批量创建活动推广计划来实现对活动方案的执行,包括在线广告、email、电话营销等;
9 T; `) X6 G7 w. [/ ec. 活动分析:记录活动成效,比如邮件打开率、转化率等进行绩效统计,以及对活动与销售数据的关系分析。
( h# X1 {% A: b8 O" `( r" m在设计过程中,功能模块要尽量紧密贴合上述 CRM 系统的整体流程,具体实现时,也可依据企业的运营或者工作方式进行特定的定制。
( X" e3 \8 S0 i& a5 M# c+ R4 }: U例如,在某些企业中市场活动管理可能更为重要,根据不同的客户属性,社交媒体营销方式有些偏年轻化公司会利用大量互联网和移动设备,而传统行业的企业上门拜访更常见。, O0 s2 i5 k9 N4 f: Z
1、适用项目:PDD 适用于更大型、复杂或需要对业务流程进行全面分析和优化的项目。
- l: j4 K& S7 u) `. T+ r0 ]& j2、工具:UML 流程图、状态图等
0 y% A3 E! w$ Q4 C+ |3、优点:帮助理清内部系统数据、业务流程,基于过程建模,从整体到局部深度设计,复杂业务简单化1 o* w/ K3 C. p7 _2 N
4、缺点:过于关注流程,导致各个子系统业务耦合较高,难以实现拓展8 T R; F3 U0 c' k0 p
3. 领域驱动设计(DDD)5 P. }- s9 J/ I) Z
领域驱动设计(Domain-Driven Design,DDD)是由领域驱动设计之父埃里克 · 埃文斯提出的,涵盖面较广,其核心思想是先梳理领域信息结构和业务规则,再梳理业务的用例、流程和操作等内容。
! f( O) M) H9 A1 c: [- c3 e整体思路遵循:确定场景领域— - 识别核心领域对象(信息结构)— - 业务规则(定义对象之间的属性关系及行为)—–其他模块的交互$ x- h. b" r7 e6 ~& @
举例:场景领域— - 电子商务平台2 D) L' ?, O) E6 ~0 @
我们识别到的核心对象为:
4 a8 W5 C5 _3 i8 P3 v9 ?商品管理:包括商品信息的管理、上架、下架、分类、标签等。2 s& S* ]# i. H
订单管理:包括订单的生成、查询、修改、删除等。 Y8 J. T8 J; j0 o( b
用户管理:包括用户信息的注册、登录、个人信息维护等。
/ j1 h2 N7 t# ]7 L5 p' {5 w ~支付管理:包括各种支付方式的接入、支付状态的管理和处理等。6 n: z% |" j6 l& V$ T
物流管理:包括订单状态的跟踪、配送信息的记录、快递单信息的管理等。
2 I* x4 J. M, d( S0 x' Z2 K" p9 h& V售后服务:包括退换货的处理、客户服务的管理、投诉反馈的处理等- X8 @& ]+ \ h$ G- j: _ d
这里以订单管理为例,用类图表达信息结构。! ~) P; L. s- ?
信息结构表述了信息内容之间的关系。这种关系可以用类图(Class Diagram)来表达。+ U( W% o3 N2 ] Q0 t
9 ]) H4 d4 A# K, u& @5 m) {! z! Z
% ^% o; \1 d9 G; c& d9 R% A, Q$ e) _# t0 D: ]
该图片来源于图书【" 图解 " 产品:产品经理业务设计与 UML 建模】作者擎苍' @- g& @5 x! o, s/ R: R5 a& r
当我们使用类图来识别领域模型和实体关系后,需要根据业务需求和限制条件定义对象、属性、操作业务规则和流程,如买家只能在特定时间段内下单,不能重复购买同样的商品;订单满足 3 人立刻成团进入待支付;订单超时未支付自动取消等。
4 ^% i. T8 V0 [. s+ y: D最后,在实现层,我们需要识别系统内的其他部分或与系统交互的部分,并确定他们对业务领域的影响。比如,与支付相关的银行接口、第三方支付接口、物流跟踪动态数据的集成等都是我们必须考虑的。# P# r1 A0 P5 \. V' x0 Y/ z
适用行业:复杂且灵活多变的行业需求,开发此软件的公司,通常是行业的引领者,如中台等大型团队项目( H% Z; b9 G/ i, b8 _- W! }
工具:UML 类图、思维导图; B- X: D' X l( v" [6 `! _
优点:低耦合可扩展、能灵活应对复杂业务变更需求、可增强代码质量
2 C7 F: a% p6 u) Z" c缺点:团队技能要求高、时间成本高、协调难度高、编码量增加(长期来看是值得的)' |. n9 {$ ]; ^3 R5 I( @
注:通过选择合适的方法论,我们完成了产品设计第 2 步:搭框架,后续再通过第 3 步拆细节,重点梳理各分支下的异常流程,逐步完善细节,最后一步,再进行页面信息收集填充,剩下的就是画原型了,此处不做展开。( s5 L' x$ j1 C# \4 O ^: c
三、面对不同项目,如何选择?
5 s( y$ L* H2 W) P7 I. C综上,通过以上 3 种搭功能框架的方法论,我们知道,产品设计方法论,包含用例驱动设计发(UDD)、流程驱动设计法(PDD ) 、领域驱动设计法(DDD),我们来整体再做个对比总结,通过以下维度进行决策,方便我们在具体的项目设计中,选择较为合适的方法。- s3 e1 g8 P3 B5 m3 T- m
# `$ {# b/ ]( Y- F' Z: c7 g: \* q
: P$ l9 v( L+ h7 d0 L9 j8 {
: o" T9 h& ?5 u
当然,他们各自有优缺点,在一个项目里,完全可以结合交叉使用。% J* W2 T' F% Z* b6 G; l; r- h. B
四、拆解需求需要具备的能力和思维0 W# e: Y1 g1 G6 \, @. ~5 S. Y
设计思维:清晰的产品设计思路、并形成自己的通用方法论,掌握并应用(如上面的 3 种方法)、包括其他的成熟模型(如 AARRR 模型…)) W; q9 Z0 c( \+ E( E$ w
设计方案:内心要有很多成熟可用的方案思维和评估方案的能力,就需要多练多看、多去关注一些最新的技术,不然没法梳理框架里具体都包含什么,怎么实现4 d$ }) B1 X; \2 U* G
深度思考能力:多使用结构化思维培养深度思考能力、体现在异常流程、外围数据交互处理上(平时要多观察竞品、多问几个为什么、包括开发阶段潜在的问题、面对开发的质疑才可以真正说不)
7 Y7 g" N4 O8 L9 y' c* U最佳的 UI 感及交互设计能力(审美、人机交互最佳策略)0 E. u$ g: \4 [4 |
工具使用能力:巧用 UML 建模,事半功倍(重点关注类图、用例图、状态图、流程图)、还有其他思维导图等7 f9 |$ y$ M( q3 g+ s% K: u" |: U w
五、其他想说的话- z3 U1 D7 l1 r& x& R
本文的重点是教大家如何通过成熟的方法论,拆解需求指导原型设计,在写的时候,里面其实包含了很多知识点,并没有展开:
7 G' \7 y7 E3 M3 O$ }比如最容易被忽视的 DFX 需求:UDD、PDD、DDD3 种方法论如何灵活保证系统的 DFX 需求,这部分产品经理必须有相应地思考和考量,不能老是产品做了用不起来或者代码混乱、后面维护难、迭代难……4 ^( C- R8 A: C4 J' j# z$ _
UML 建模能力的学习:高效辅助产品经理工作,梳理需求和团队协作、包括作为评审材料后期可进行系统设计检视,很值得研究运用,但不是都要学;
/ R& `( ^7 A+ L: u( [. C再比如产品设计由静态到动态,框架的各个模块之间如何进行交互设计关联;页面信息结构怎么收集并合理展示…… ..
P! o# }, ~# [0 s: ? ~; b4 J后续我也会慢慢整理总结、输出。
, T+ n) \" Z! W M" L7 j最后,我们还可以问自己一个问题,从程序员角度,逆向考虑下,程序员拿到一个需求,都是怎么拆解并实现的?- h9 D6 `- G; q. S8 N3 u _1 y7 W
或许你会知道,你设计的功能是不是相对完美的。" k a i+ d- n" ^# u
本文由 @凯拉 Kella 原创发布于人人都是产品经理,未经作者许可,禁止转载。
) j! k3 A: H2 ~0 ~题图来自 Unsplash,基于 CC0 协议。 |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|