写PRD时的思考自查表
在本文作者看来,PRD像解分情况讨论题,最后得分早在你决定分几种情况时已经落定,这篇文章将重点讨论解题思路。
PRD,产品需求文档,像厨艺切磋里的终极菜单的──蛋炒饭,人人会写的PRD其实藏着很多智慧、并时时暴露着你的思维死角。正儿八经当了一年的产品,写PRD的心态翻天覆地,从当做写文档、表格要漂亮、原型要精致,到认识到这是项目的基石,项目成员对你的信任度、项目的开发效率、项目最后的成就从发出PRD那一刻就开始发生着微妙的变化。
我现在希望,我们之间最质朴的交流,是我的PRD能回答你。
解题基本功
PRD的一切都围绕着需求:需求从哪里来、怎么落地这个需求、怎么衡量需求的落地效果。有PM笑称产品的日常就是在解应用题,只是“水池的进水速度、出水速度”这样的条件没有写在题干里。PRD相当于你交出的考卷,解题背景、解题思路和最后得分一目了然。
我说PRD像解分情况讨论题,最后得分早在你决定分几种情况时已经落定,这篇文章将重点讨论解题思路。根据我的踩坑经验,考虑缺失的苦果或早或晚会猝不及防的出现,让你狼狈一阵子。现在学乖的我至少会考虑三个大方面的需求:
- 功能需求。需要增加产品支持的使用场景,例如微信增加“搜一搜”,来让用户在微信中获取更多的内容、再次重打“用完即走”这句话的脸。这个很好理解,加功能或者优化已有功能以丰富应用场景,是大多数产品的日常,尤其在创业公司。
- 性能需求。自己狠狠踩过了调用接口超时的坑,才开始关注功能相关的性能问题。当时做需求中包含一个触发数据同步的功能,我只简单说明了同步流程。到用外网数据库测试时才发现,当数据量较大时,调用同步接口会超时,而不得不临时改变策略。类似问题还出现在批量上传没有考虑数量上限、下载不考虑是否需要异步处理、没考虑过图像清晰度和加载时间的平衡、完全不考虑浏览器兼容等。尽管有经验的研发会自己处理性能问题,有经验的产品应该在研发做技术设计之前抛出自己对性能的要求。
- 安全需求。看别人狠狠踩过了没有反爬虫策略的坑,才开始关注安全性问题。除了反爬虫外,有些功能需要进行敏感词屏蔽(同步过滤和异步召回)、防刷单机制等。安全需求暂时涉猎较少,不展开描述。
十四字思考自查表
画一张脑图,主题叫做“落地需求”,第一级标题划定为“功能需求”、“性能需求”、“安全需求”,子标题是什么呢?换句话说,就是该怎么思考落地方案呢?
高人传我七字箴言“增查改删显算传”。结合本人的经验,狗尾续貂为十四字:
“增查改删显算传,异常情况也要盘。”
“增查改删显算传”的每个字的扩展,可以用“5W2H”来帮助思维延伸。问问自己这个操作是否必要(why)、操作的权限如何分配(who)、操作的时效限制(when)、交互邀请和提示怎么做(where)、可操作内容是什么(what)、操作的主流程和异常情况是什么(how)、整个操作要多少步骤(how much)。下面具体说说:
- “增”我理解为创建过程。创建的入口在哪?创建的条件是什么?有什么输入参数,必填吗?
- “查”我理解为查找。是否支持查找?以什么方式查找,搜索、标签or排序?全局搜索or类目下搜索?精确搜索or模糊搜索?什么情况下搜索屏蔽结果?搜索结果可以进行什么操作?如何退出搜索?静态标签or动态标签?
- “改”我理解为编辑。编辑的入口在哪?编辑的条件是什么?什么参数支持编辑?
- “删”我理解为删除。删除的对象是什么?删除的条件是什么?怎么删除?是否可以撤回?需不需要回收站?
- “显”我理解为显示。显示的内容是什么?显示内容的优先级的逻辑是什么?视觉元素显示的优先级是什么?层级关系是什么?
- “算”我理解为数学相关。增查改删显传的数值限制是多少?有什么计算或数量变化规则?用户需要的内容数量是多少?是否需要显示总数?
- “传”我理解为传输,包括转发、分享、下载等。这里需要思考传输是否需要处理状态。
- “异”我理解为异常情况。小到增查改删各个步骤的可能出现的错误情况、大到预估服务器的最大并发,产品能感知到自己解决方案的风险越多、对异常情况准备越充分,就是省钱省力。对异常情况的预知能力,一定程度上反映了产品的经验值。
勤于修炼,方得始终
我想“面向对象”和“面向过程”这两种建模方式不止适用于编程,也很适用于产品的日常解题。这篇文章中重点说的是一种“面向过程”的思考方式,小、具体、细致,对产品的抽象思维能力没有提出太多的要求,非常适合用来锻炼产品基本功,以达成思维层级一的目标:完整的闭环。
最近做的一个后台功能,主流程就是用户上传CAD文件、完成必须入参填写,完成上传的一个过程。用这个例子来带大家走一遍“十四字箴言”的思考流程。
1. 增
(1)创建条件
- 完成素材上传的需要的必须参数有哪些(文件、名称、尺寸、材质等)?
- 用户上传的CAD文件内容的要求是什么?
- 名称长度、字符的要求是什么?
- 尺寸范围是什么?
- 支持添加的材质是什么?
(2)异常情况
- 不符合要求的文件处理方式是什么?
- 超过长度的名称怎么处理?
- 超过尺寸范围怎么办?
2. 查
查询方式:
- 添加材质时,如何快速查找到需要的素材?
- 搜索支持的字符是哪几种?
- 模糊搜索还是精确搜索?
- 如何退出搜索结果?
3. 改
(名称和尺寸的编辑不赘述)
(1)编辑入口
重新上传文件的入口存在于几个地方?设置区域组合关系、设置区域与材质映射关系时是否需要重新上传文件的入口?
(2)编辑条件
已经设置好区域的组合关系后,是否支持再次编辑区域成组方式?
(3)编辑逻辑
再次编辑成组时,如何确定每个区域材质信息?
4. 删
所有右上角的“×”关闭路径是什么?
5. 显
(1)点击状态
上传完成之前,完成上传、继续上传按钮是否可点击?在进行区域成组操作时,进入材质映射步骤的按钮是否可点击?
(2)显示内容
初次打开页面、上传中间状态、上传完成状态分别显示什么?
6. 算
区域和材质的映射关系是一对一还是多对一?
7. 传
加载状态:读取文件、渲染图片等状态是否需要考虑加载状态?加载中、加载成功、加载失败等。
以上是我在提笔写PRD前,按照十四字口诀列出的思考自查表。
平时在进行竞品功能调研的时候,也可借助这张自查表较为完整的列出功能的实现逻辑、以及边缘情况的处理方案。有时候在调研过程中,看到竞品产品对细节处细腻的处理,会有种想要大呼对手高明的冲动。
大家不妨试试用这套逻辑来分析一个功能练练手,例如淘宝的“我的收藏”、微信通讯录等,勤于修炼、方得始终。
思维层级的递进
沉沦于面向过程的思考会失去系统的分析的高度,说人话就是功能做的太多不要忘记抽象和沉淀,否则容易迷失在细节围城的迷宫。
入行这一年修炼的最多的还是具体的细节逻辑,沉淀这一套通用解法,面对各种场景也能有一些思考的线头。
下一步就是锻炼“面向对象”的系统性思考方法,有所心得再与大家分享。
作者:zhihui
来源:微信公众号【周一产品】
本文由 @zhihui 授权发布于人人都是产品经理,未经作者许可,禁止转载。
题图来自 Pexels,基于 CC0 协议
相当受教,麻烦大佬以后多多分享,感谢感谢!
之前很少写word的PRD,缺乏思路
这篇文章相当受用
还有区域成组、材质映射
材质是什么
很好
感谢
受用
奈斯! 😳
很早之前就需要这种文章,一直没找到,最终还是在试错的过程中零碎学习到这些知识。文章写得不错!
工作一年的产品可以写出自查表,非常厉害~赞
我觉得可以。👍🏻
mark 对新人有帮助
良心文章~感谢大大
很受启发,特别对于后端产品来说~
大家好,我是周杰伦
谢谢分享,很有用哈哈
赞
很赞
非常赞
很多人写prd不认真啊 边做边改
写PRD时的思考自查表写PRD时的思考自查表写PRD时的思考自查表写PRD时的思考自查表写PRD时的思考自查表写PRD时的思考自查表