如何做需求收集
做需求收集有很多方法论,我个人认可的有以下这些
- 用例 (Use Case)
- 用户故事 (User Story)
- 用户故事地图 (User Story Mapping)
- 影响地图 (Impact Mapping)
用例
用例是一种识别、澄清和组织系统需求的方法论。它一般配合UML图一起使用,是一种有效的需求沟通工具。它是最早出现的需求收集分析的方法论。
以下是一个用例图的示例
graph LR A[Actor] --> B((Use Case 1)) A --> C((Use Case 2)) B --> D{System} C --> D D --> E[Actor] D --> F[Actor]
用例技术非常有用,但是也存在局限性
使用use case收集分析需求的局限性包括以下几点:
复杂性:使用use case方法需要详细描述系统的各种功能和交互,特别是在大型系统中,可能会导致大量的use case,难以管理和维护。
语言障碍:use case通常使用专业的技术术语和领域特定的语言,可能会导致与非技术人员的沟通困难。
详细度:use case需要详细描述系统的各种功能和交互,可能会导致过度关注细节而忽视整体需求。
可变性:use case通常是一次性的文档,一旦编写完成,很难进行修改和更新,随着需求的变化,可能会导致use case的失效。
为了解决use case方法的局限性,用户故事(user story)方法产生了。
用户故事
用户故事是一种简洁的描述用户需求的方法,强调与用户的对话和协作,而不是详细的文档。用户故事通常以如下形式描述:作为一个[角色],我想要[目标],以便[原因]。用户故事易于理解和记录,并且可以随时修改和更新,以适应需求的变化。此外,用户故事注重用户价值和用户体验,更侧重于用户需求的核心,而不是过度关注技术细节。因此,用户故事方法更加适用于敏捷开发等快速迭代的开发方法。
用户故事是敏捷开发中的一种需求描述技术,它用简洁的语言描述用户的需求和期望,以便开发团队能够更好地理解用户的需求并提供相应的解决方案。
用户故事通常包含以下要素:
角色:用户故事描述了一个特定的用户或角色,例如“作为一名购物者”或“作为一名管理员”。
目标:用户故事描述了用户想要实现的目标或期望的结果,例如“我希望能够浏览商品并添加到购物车”或“我希望能够管理用户账户”。
动作:用户故事描述了用户采取的行动或操作,例如“我点击商品列表并浏览商品详情页面”或“我登录系统并更新用户信息”。
价值:用户故事描述了用户从实现目标中获得的价值或好处,例如“通过浏览商品并添加到购物车,我能够方便地购买所需的商品”或“通过管理用户账户,我可以更好地控制和保护我的个人信息”。
用户故事通常以以下格式进行描述:作为一个[角色],我想要[目标],以便[价值]。开发团队可以根据用户故事来制定开发计划、优先级和测试方案,以确保最终产品符合用户的需求。
用户故事很棒,但是当你有成百上千个用户故事卡片,如何得到一个全局视图而不迷失在细节碎片中呢?如何为这些需求规划优先级呢?
为了解决这些问题,用户故事地图方法诞生了
用户故事地图
用户故事地图是一种工具,用于可视化和组织用户故事。它是一个二维图表,横轴表示用户故事的优先级,纵轴表示用户故事的主题或功能。用户故事地图按照用户的需求和优先级进行排列,使团队可以清晰地了解整个产品的功能和用户需求。
用户故事地图有以下几个用途:
产品规划:用户故事地图可以帮助团队理解产品的整体功能和用户需求,以便更好地进行产品规划和决策。
优先级排序:通过用户故事地图,团队可以根据用户故事的优先级进行排序,确定哪些功能是最重要的,以便在开发过程中优先实现。
交流和沟通:用户故事地图可以作为一个视觉化的工具,帮助团队成员之间更好地交流和沟通,共享对产品功能和用户需求的理解。
追踪进展:通过用户故事地图,团队可以清晰地了解每个用户故事的状态和进展情况,以便及时调整和管理开发进度。
用户故事地图很好,但它是一种相对重量级的规划,同时它并没有产品带来的商业价值给予足够的考虑。在增长黑客方法论的引领下,
一种更适应快迭代,更强调组织业务目标的方法论产生了
影响力地图
影响力地图是一种轻量级的、协作的规划技术,适用于希望通过软件产品产生巨大影响的团队。它基于用户交互设计、结果驱动的规划和思维导图。影响力地图帮助交付团队和利益相关者可视化路线图,解释交付成果如何与用户需求相连接,并传达用户结果与更高级别组织目标之间的关系。
影响力地图包括以下要素:
组织目标:描述了组织希望实现的最终目标或结果。
用户结果:描述了用户希望通过软件产品实现的具体结果或价值。
交付成果:描述了软件产品或功能的具体交付成果。
任务:描述了为实现交付成果而需要执行的具体任务或行动。
graph LR A[Organizational Goal] --> B(User Outcome) B --> C(Deliverables) C --> D(Tasks)
总结
Use Case解决了清晰结构化描述需求的问题
User Story鼓励更多直接沟通,而不是通过文档沟通
User Story Mapping用于组织和规划大量的User Story
Impact Mapping强调业务目标的达成,只做对组织目标有益的事