京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 981|回复: 0

大厂方法论 + 案例:从 0 到 1 轻松拆解产品需求,对程序员的质疑说不 ...

[复制链接]

1611

主题

740

回帖

6663

积分

论坛元老

积分
6663
发表于 2023-6-16 18:18:22 | 显示全部楼层 |阅读模式 来自 中国
产品需求是如何落地到原型设计的?本文将结合案例和大厂产品经理常用的方法论,通俗化讲解如何系统拆解产品需求,希望对你有所收获。9 t6 P" ~7 |  s1 _) F8 d

5 C! v: `2 R9 e5 d& j$ H3 |' Y- {- X$ w9 ~: Q+ I
# K+ \6 r5 i+ z0 G# ?4 B
一、产品经理设计思路是什么样
. L/ R7 i4 A, L! A9 h6 j面临新业务线拓展或者产品升级的时候,在收集到一大堆乱七八糟的需求后,你可能会想,我要怎么着手呢?答案是,搭框架找思路。
( W* G/ t/ [+ v/ u, [# D% L0 c这是一个产品经理通用的设计思路框架,遵循由粗到细、自上而下的流程,具体如下:
! t+ ~0 H% F7 R+ U战略层—–业务目标是什么,即定方向,含用户、使用终端、市场竞争力和解决方案、项目计划;想清楚做什么,即把具备价值的需求进行梳理优先级排序包括形成产品初步架构3 G$ t& n1 N; _- `7 F0 {
搭框架—–(功能和 DFX 非功能框架)难点在于梳理功能的全面和思路;dfx 需求:保证用户使用产品的安全、性能、可拓展等需求注:DFX 其实很重要但大部分都会被忽视,此文不做拓展、后续会通过一篇文章进行详细说明,(产品经理千万不能只盯住功能做产品)
/ u; _+ w6 z7 e8 K拆细节—–业务流程(重点梳理异常分支和外围数据交互)、业务操作、信息结构)7 }+ m- b1 K) J( ^5 `+ U
画界面—–交互设计、信息设计
8 v' q/ @( P. o/ M4 `5 d7 G8 c以上的思路大家可以按需参考,本文着重讲解拆解 2 步骤的方法,即搭建初步功能框架,并可落地到原型指导设计。; ~3 S0 L2 {/ B0 _; N  H! P5 Y
二、如何搭建功能框架呢?; W$ s4 w8 Y* _1 w) H& M* t6 |0 C
注:搭功能框架也是从宽度上定义业务范围,而不是要深挖细节、要注意避免陷入思路混乱、把握好分寸、见好就收。/ R% I: ]! ~" m1 e
1. 用例驱动设计法(UDD)
1 [, M: a* u# e用例驱动设计是一种基于用户行为和需求来设计软件开发的方法,有步骤有层次梳理出系统功能的方法,可粗浅理解为用户故事,是一个通用的搭框架方法;如类似网购下单、酒店预定、银行贷款等场景;/ a7 G4 N; s% m% N2 a9 H
整体思路遵循:识别参与者使用场景及问题—–定义描述用例(目标层用例—步骤层用例— - 实现层用例)并简化( f6 w; L% t9 o& p8 j
(1)识别使用场景及问题- X6 Z3 [- @3 F3 I! o+ w
首先,我们通过华为 IPD 需求管理思路那篇,知道产品需求 = 基于场景的解决方案,因此拿到一个产品需求,我们需要想清楚对应的场景,即 5w1h1e。! B/ w) W3 I& s8 x
who(面向对象)、why、when+where(场景)、what(干什么)、以及 how(怎么实现)、else(限前置和后置)
" p/ U9 h5 W" }比如要做一个访客预约系统,按照上面的描述方法,我们明白了系统的使用场景是这样:; z; h; U6 s: l
一个基于外来访客,由于园区为了保障安全管理,在临时进入园区前,需要进行线上登记个人资料、并实名认证的产品,并且园区审核通过,验证身份才可以进入和离园。
) \6 J. a  x! R$ B% Z+ c$ @8 E(2)拆分:目标层 - 步骤层 - 实现层
8 o" j& b2 m  G5 l结合上面的例子:4 D' q) D) M6 I+ \& `# W
访客进入园区就是目标层用例,为了实现这个整体目标,我们需要步骤层用例进行支撑,这时候就可以拆分为第一个大框架
1 O: D# q+ d- ?0 t具体为:
$ r8 i: |8 \  s4 O步骤 1:访客在系统上提前登记—–线上预约6 O; I% f+ G& K& ]
步骤 2:访客填写登记资料—–填写表单
* W: a, }! D% o步骤 3:园区通过系统审核资料并通知访客结果—–审核管理5 v) a1 c% U. d
步骤 4:访客接收通知— - 消息提醒
1 c0 N- d7 d! U  T2 @* d) f步骤 5:访客查看提交记录—–预约记录7 `/ Y% q: i: r$ A4 V2 }
步骤 6:访客获得许可进入园区—身份验证- A$ g, {6 {: O' s3 P
步骤 7:访客离园确认—身份验证' ]  s4 `; M1 z" T! `8 d, C
那针对每一个步骤层、具体如何实现呢?按照这个思路,通过拆分形成实现层用例(也就是用什么方案实现); p, d. D! H* B4 _" m, a" C
最终这个功能框架会形成这样、(注意把不同用户端分开保证用例全面)如图:
* C4 s7 a4 [; g% g3 S2 ?& R5 s. L0 s7 v9 D8 z3 ~6 H
; r1 {6 s( X( Q9 t4 V' G4 x

2 y- x$ B/ ~5 B4 r) t当然这是初步框架,仅作部分举例说明,你们可以自行拓展,只要保证覆盖全部的用例就行。) B0 `0 e/ A# K5 I% r* s
在这里,我们要注意几点:6 ?- S: F; T+ {4 h1 l! O" H. ]" }
在多种实现方案并存的情况下,如何权衡呢?
9 h+ _* B8 W+ c( X1、结合功能实现成本、第三方对接周期、客户需要、技术实现能力、外围的交互模块等多方面因素进行决策,选择一个较为合理的实现方案:6 S5 g6 v. Z" U8 C1 C+ V$ z
2、如上面的进出身份验证,给了 4 种方案,有通行扫码、临时卡、人脸识别、指纹、语音,包括我们常见的支付也可以多种路径实现,如现金支付、信用卡支付、微信支付等3 V6 D# d' Z6 t4 n6 Z0 E
小结:
4 X7 P; k6 V% F! B1、工具:建议用思维导图、或者用例图进行梳理  ?$ Z, O- F6 s2 f$ p
2、目标:是形成产品功能结构(含一级特性、二级特性、甚至三级特性)9 j( U+ {# ?$ x' x3 w
3、适用项目:比较独立、小型或需要快速迭代和更新的项目,注重从用户的角度出发来描述系统的功能需求
- I, g# U; {2 C4、特点:方便快捷、拓展性较差、易于理解协作,但难以适用复杂业务
) q, X7 {3 v; m# M* k( Q 2. 流程驱动设计法(PDD)* D  u+ a; l$ m& y! C0 q& T- F
适用于业务协作方较多,具备较复杂的业务层级及审核,更注重流程标准化管理的产品,如 CRM、ERP 系统、工单管理系统、采购系统、数据精细管理等。$ O$ A" f% Y# `  i, Q
整体思路遵循:识别关键业务流程—–拆分目标层用例—–业务操作
# o) ]# U9 `8 A2 R5 a! b比如 CRM 系统的流程是有明显前后顺序的,且为了精准做好客户关系管理,标准化的流程非常重要。通常按照以下步骤进行操作:  D% Q1 m% P! G2 G" T; c
1、客户档案创建和维护—–客户管理流程
# y: N& C, S) \3 p' O' U- t( C- [2、销售机会(Lead)创建和跟进——销售管理流程( e# }# W, p, w# D& m6 K
3、市场活动的策划、执行和跟进—— - 市场活动管理流程0 l  J+ v- k& ]* ~5 Z0 r# J
结合以上顺序流程,就很适合用 PDD 来搭框架,我们大概拆分出几个目标层,并进一步落地到具体的功能模块中。下面是一些可能包括的模块:' M. Q' X7 m7 x: M0 e+ T' A# k
客户管理模块:3 g) ^1 V% P$ q
a. 客户档案:创建、查看、编辑、删除客户资料;9 a# o; g3 X2 u; |
b. 客户分类:对客户进行分组和标记,例如根据客户来源、优先级、交易状态等进行分类;6 @: g2 Y: `5 |8 J, [
c. 客户关系历史记录:记录客户与企业之间的活动历史,包括通话、邮件、漏斗进展等。+ J4 t0 A  ]( k" D0 H9 i, ~! `
销售管理模块:
5 w, x% l6 p  c8 M; q8 `3 Pa. 销售机会(Leads):创建、跟进、评估及关闭销售机会,可以关联相关的客户信息;2 K4 t* c( A+ |# t5 S3 E8 \
b. 产品 / 服务信息:录入、查看、编辑和删除产品或服务信息;
+ j) c3 O- r% M/ I" @+ u! Lc. 报价单 / 订单:创建、发送、听取意见、确认并完成报价和订单交付等流程;! w/ G" c5 e; ^0 ^& X) c3 L% t- b
d. 合同信息:建立一个合同管理库存储合同信息,以追踪合同执行情况和收款计划。
# H  O0 n& }" x- i, w市场活动管理:
9 U0 K: a& a! H! d/ f! ^- \0 da. 活动策划:创建市场活动,定义主题,摘要、预算、时间表等参数;
" @8 k6 V% \4 M+ D" f) lb. 活动跟踪:批量创建活动推广计划来实现对活动方案的执行,包括在线广告、email、电话营销等;
! M0 w( G* w! X* c8 Lc. 活动分析:记录活动成效,比如邮件打开率、转化率等进行绩效统计,以及对活动与销售数据的关系分析。
9 Z7 ~- j. z! y! k在设计过程中,功能模块要尽量紧密贴合上述 CRM 系统的整体流程,具体实现时,也可依据企业的运营或者工作方式进行特定的定制。
8 J; V0 d6 H5 ^4 Y4 p. L例如,在某些企业中市场活动管理可能更为重要,根据不同的客户属性,社交媒体营销方式有些偏年轻化公司会利用大量互联网和移动设备,而传统行业的企业上门拜访更常见。
! F) |9 s) H$ K7 I6 v% t. {: O1、适用项目:PDD 适用于更大型、复杂或需要对业务流程进行全面分析和优化的项目。$ X' V7 b3 i& J0 j4 d% j6 W( d+ \
2、工具:UML 流程图、状态图等9 [, S! l7 D3 N# y  v  L, j
3、优点:帮助理清内部系统数据、业务流程,基于过程建模,从整体到局部深度设计,复杂业务简单化
5 ]& o1 Q# h7 v% |4、缺点:过于关注流程,导致各个子系统业务耦合较高,难以实现拓展
% q( V& B+ ]5 n1 g$ a4 C 3. 领域驱动设计(DDD): g( z, o" X& Y8 L. M
领域驱动设计(Domain-Driven Design,DDD)是由领域驱动设计之父埃里克 · 埃文斯提出的,涵盖面较广,其核心思想是先梳理领域信息结构和业务规则,再梳理业务的用例、流程和操作等内容。% r1 Z6 Z5 x2 p8 E6 b5 [% L$ @* F; V
整体思路遵循:确定场景领域— - 识别核心领域对象(信息结构)— - 业务规则(定义对象之间的属性关系及行为)—–其他模块的交互
* l3 `, g- N/ Q# a; E举例:场景领域— - 电子商务平台! W5 f0 V  S$ u* O+ K$ b9 t, g
我们识别到的核心对象为:8 _; `' d& y& b9 B
商品管理:包括商品信息的管理、上架、下架、分类、标签等。
+ Q, Z9 d  [0 d3 G订单管理:包括订单的生成、查询、修改、删除等。
& r# P/ }$ ]. \8 x. i4 m% e用户管理:包括用户信息的注册、登录、个人信息维护等。0 [& m6 ?2 {" ~5 a- C5 i+ O$ `
支付管理:包括各种支付方式的接入、支付状态的管理和处理等。
' T$ `0 B- j# d8 l# s  w% N物流管理:包括订单状态的跟踪、配送信息的记录、快递单信息的管理等。2 P2 H5 v$ i+ Y/ v9 f6 Y9 p
售后服务:包括退换货的处理、客户服务的管理、投诉反馈的处理等1 {" T0 |# X+ o' I: {- V
这里以订单管理为例,用类图表达信息结构。: \6 C; r  Y( p  T4 Y7 Q2 G
信息结构表述了信息内容之间的关系。这种关系可以用类图(Class Diagram)来表达。
0 X/ \/ E7 ^% D9 u% k
' Q# k7 f9 M% V0 t; G4 c6 W
6 ^! s( d  E2 g! }7 L0 I3 W3 @$ X$ N* d9 c4 i4 k
该图片来源于图书【" 图解 " 产品:产品经理业务设计与 UML 建模】作者擎苍
% a! N" v- o2 n0 c" N- W2 Y当我们使用类图来识别领域模型和实体关系后,需要根据业务需求和限制条件定义对象、属性、操作业务规则和流程,如买家只能在特定时间段内下单,不能重复购买同样的商品;订单满足 3 人立刻成团进入待支付;订单超时未支付自动取消等。# v; ~% b+ T: I; _3 j. m9 S# N
最后,在实现层,我们需要识别系统内的其他部分或与系统交互的部分,并确定他们对业务领域的影响。比如,与支付相关的银行接口、第三方支付接口、物流跟踪动态数据的集成等都是我们必须考虑的。* F% b) m& B7 X# C6 T$ n# r
适用行业:复杂且灵活多变的行业需求,开发此软件的公司,通常是行业的引领者,如中台等大型团队项目
2 R+ N! h8 a; q5 y/ j# }- F+ R8 _工具:UML 类图、思维导图
1 y3 i+ c' m% X! U0 {- t优点:低耦合可扩展、能灵活应对复杂业务变更需求、可增强代码质量9 S% ~2 ?$ @8 |
缺点:团队技能要求高、时间成本高、协调难度高、编码量增加(长期来看是值得的)
9 w6 Q1 L! L: H7 p1 l注:通过选择合适的方法论,我们完成了产品设计第 2 步:搭框架,后续再通过第 3 步拆细节,重点梳理各分支下的异常流程,逐步完善细节,最后一步,再进行页面信息收集填充,剩下的就是画原型了,此处不做展开。3 y5 H! e8 ~" c2 k1 S% d8 y4 O% g
三、面对不同项目,如何选择?
$ k0 X7 ~# v' `5 Z; B5 O综上,通过以上 3 种搭功能框架的方法论,我们知道,产品设计方法论,包含用例驱动设计发(UDD)、流程驱动设计法(PDD ) 、领域驱动设计法(DDD),我们来整体再做个对比总结,通过以下维度进行决策,方便我们在具体的项目设计中,选择较为合适的方法。
' R! m. b2 N2 W" t3 T8 w5 {: G, q6 U
4 X  f9 s9 P& T# {

+ o: M- f: H6 L: h5 b+ ~  C$ k当然,他们各自有优缺点,在一个项目里,完全可以结合交叉使用。
6 e0 Y2 q' i! I$ k- E( @+ m 四、拆解需求需要具备的能力和思维3 v; P/ D0 g3 E" [$ a# r& W! z
设计思维:清晰的产品设计思路、并形成自己的通用方法论,掌握并应用(如上面的 3 种方法)、包括其他的成熟模型(如 AARRR 模型…)
# \! t& T2 Z$ b9 G. U设计方案:内心要有很多成熟可用的方案思维和评估方案的能力,就需要多练多看、多去关注一些最新的技术,不然没法梳理框架里具体都包含什么,怎么实现
) k; l4 ?4 Y& g% h+ ^1 q. {' `- r深度思考能力:多使用结构化思维培养深度思考能力、体现在异常流程、外围数据交互处理上(平时要多观察竞品、多问几个为什么、包括开发阶段潜在的问题、面对开发的质疑才可以真正说不). g5 t7 i1 j3 D! L; x2 N
最佳的 UI 感及交互设计能力(审美、人机交互最佳策略)
7 }) N' V* W! N- }+ X工具使用能力:巧用 UML 建模,事半功倍(重点关注类图、用例图、状态图、流程图)、还有其他思维导图等% {8 Q; n3 X9 `0 Q6 h
五、其他想说的话
- H1 y6 l7 d3 J: n& L* h4 W本文的重点是教大家如何通过成熟的方法论,拆解需求指导原型设计,在写的时候,里面其实包含了很多知识点,并没有展开:- @% P; P( [) V) h) C  S4 n
比如最容易被忽视的 DFX 需求:UDD、PDD、DDD3 种方法论如何灵活保证系统的 DFX 需求,这部分产品经理必须有相应地思考和考量,不能老是产品做了用不起来或者代码混乱、后面维护难、迭代难……9 V  U2 Y) v( f  n2 ]$ k6 U
UML 建模能力的学习:高效辅助产品经理工作,梳理需求和团队协作、包括作为评审材料后期可进行系统设计检视,很值得研究运用,但不是都要学;
  r/ s4 @, \: U. i再比如产品设计由静态到动态,框架的各个模块之间如何进行交互设计关联;页面信息结构怎么收集并合理展示…… ..8 r1 R( P1 k$ u# `  ]0 M# B
后续我也会慢慢整理总结、输出。- t2 ], |8 _0 F9 o
最后,我们还可以问自己一个问题,从程序员角度,逆向考虑下,程序员拿到一个需求,都是怎么拆解并实现的?7 D2 x8 q4 a; K% o' M& P# n; N
或许你会知道,你设计的功能是不是相对完美的。
$ W. D) B( j3 n/ T本文由 @凯拉 Kella 原创发布于人人都是产品经理,未经作者许可,禁止转载。$ b* u0 J3 r+ A( d3 t& q% e
题图来自 Unsplash,基于 CC0 协议。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2026-5-30 04:15 , Processed in 0.038577 second(s), 24 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表