我们来详细解析一下用户故事(User Story),包括其结构、为什么重要、如何编写好的用户故事以及一个完整的示例。

1. 用户故事的基本结构:三段式模板

最经典和通用的用户故事模板就是您提到的三段式:

  • As a [角色]:

    • 目的: 明确我们为谁构建这个功能。它定义了特定的用户类型或角色。

    • 示例: “As a 未登录的访客”, “As a 管理员”, “As一个经常出差的销售代表”。

  • I want to [动作]:

    • 目的: 描述用户想要执行的具体操作或功能。这是故事的核心目标。

    • 示例: “I want to reset my password”, “I want to filter search results by date”, “I want to export my data as a CSV file”。

  • So that [价值/收益]:

    • 目的:****这是最重要的一部分。它阐明了用户为什么要做这个动作,以及他们能从中获得什么商业价值或个人收益。这确保了团队是在为用户解决真实的问题,而不是仅仅实现一个功能。

    • 示例: “So that I can regain access to my account”, “So that I can quickly find last week’s transactions”, “So that I can analyze the data in Excel and prepare my report”。


2. 为什么这个格式如此重要?

这个简单的格式迫使团队(包括产品负责人、开发、测试等)在讨论功能时始终思考三个关键问题:

  1. 为谁设计? (用户中心)

  2. 要做什么? (功能需求)

  3. 为什么做? (商业价值)

这避免了团队在不明就里的情况下开发一些“听起来不错”但实际上没有价值的功能。


3. 一个完整的用户故事还包含哪些部分?

在实际项目中,一个用户故事卡片(无论是在Jira、Trello还是物理便利贴上)通常还会包含以下关键信息:

  • 对话 (Conversation): 用户故事不是一个详细的需求文档,而是一个承诺进行对话的提醒。开发团队和产品负责人需要不断沟通以澄清细节。这些对话通常记录在卡片上或相关的会议中。

  • 验收标准 (Acceptance Criteria - AC): 这是定义故事何时“完成”的规则列表。它是一组可测试的条件,通常以“Given/When/Then”(GWT)格式编写。

    • 示例(针对重置密码的故事):

      • text

        Given 我在登录页面,当我点击“忘记密码”链接,Then 我应该被带到一个可以输入邮箱的页面。
      • text

        Given 我输入了已注册的邮箱并提交,Then 系统应发送一封包含重置链接的邮件。
      • text

        Given 我点击了邮件中的有效重置链接,Then 系统应提示我输入新密码。
      • text

        Given 我输入了新密码并确认,Then 我的密码应该被更新,并且我可以用新密码登录。
  • 优先级和估算: 产品负责人会为故事排列优先级,开发团队会估算完成它所需的工作量(通常用故事点表示)。


4. 如何编写好的用户故事?—— INVEST 原则

一个好的用户故事应该符合 INVEST 标准:

  • Independent (独立的): 尽可能与其他故事减少依赖,便于规划和排序。

  • Negotiable (可协商的): 故事不是合同,其细节可以通过对话来调整。

  • Valuable (有价值的): 必须对用户或客户交付价值(So that...部分确保了这一点)。

  • Estimable (可估算的): 团队应该能够估算其工作量,规模不能太大或太模糊。

  • Small (小的): 故事应该足够小,以便在一个迭代(Sprint)中完成多个。大型故事需要被拆解。

  • Testable (可测试的): 必须有明确的验收标准来验证是否完成。


5. 示例:从模糊需求到完整的用户故事

模糊的需求: “我们需要一个密码重置功能。”

一个优秀的用户故事:

标题: 用户重置密码

用户故事:

  • As a 忘记密码的注册用户

  • I want to 通过电子邮件接收一个链接来重置我的密码

  • So that 我可以在不联系客服的情况下自行恢复账户访问权限。

验收标准 (AC):

  • Given 用户点击了“忘记密码”链接,When 他们输入了一个在系统中未注册的邮箱地址并提交,Then 应显示一条通用成功消息(如“如果邮箱已注册,重置链接已发送”),而不会透露邮箱是否注册。

  • Given 用户点击了“忘记密码”链接,When 他们输入了一个已注册的邮箱地址并提交,Then 系统应向该邮箱发送一封包含唯一重置链接的邮件。

  • Given 用户点击了邮件中的重置链接,When 链接在24小时有效期内,Then 用户应被引导至一个设置新密码的页面。

  • Given 用户点击了邮件中的重置链接,When 链接已过期,Then 用户应看到错误消息,并提示他们重新申请重置链接。

  • Given 用户在设置新密码页面,When 他们提交了符合复杂度要求的新密码,Then 系统应更新密码,并提示用户密码已重置成功,并允许他们用新密码登录。


总结

用户故事是一个强大而简单的工具,它将需求从冰冷的“系统应该”陈述,转变为以用户和价值为中心的对话。记住:“As a... I want to... So that...” 是核心,对话验收标准是使其完整和可执行的关键。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/96305.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/96305.shtml
英文地址,请注明出处:http://en.pswp.cn/web/96305.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【OpenGL】LearnOpenGL学习笔记20 - 实例化 Instancing

上接:https://blog.csdn.net/weixin_44506615/article/details/151156446?spm1001.2014.3001.5501 完整代码:https://gitee.com/Duo1J/learn-open-gl | https://github.com/Duo1J/LearnOpenGL 实例化 Instancing 以往当我们在场景中要大量绘制相同模型…

MySQL主从不一致?DBA急救手册:14种高频坑点+3分钟定位+无损修复!

MySQL「主从不一致」最常见的成因、快速定位思路以及可落地的修复手段 一、为什么会不一致?14 类高频场景类别典型表现/触发条件快速自检命令/日志1. 从库被写入业务或 DBA 直连从库 UPDATE/INSERTSHOW VARIABLES LIKE read_only 应为 ON2. 复制过滤规则主从 binlog…

AI 网站源码:探秘 SUNO,革新音乐创作的 AI 先锋

在当今数字化浪潮中,人工智能(AI)正深刻地重塑各个领域,音乐创作也不例外。SUNO 作为一款引领潮流的音乐生成工具,宛如一颗璀璨新星,在音乐创作的天空中熠熠生辉,为音乐爱好者和创作者们带来了前…

Linux:malloc背后的实现细节

目录前言一、先搞懂基础:程序的内存布局(关键前提!)二、malloc的核心实现步骤(4层架构拆解)第1层:用户调用 → 标准库处理(glibc的malloc.c)第2层:堆内存池管…

什么是X11转发?

X11 转发(X11 forwarding,ssh -X)是一种 SSH 协议功能,它允许用户在远程服务器上运行图形化应用程序,并通过本地的显示设备和输入输出设备与这些程序进行交互。它被开发者广泛使用,用于在大规模、异构的服务…

Android Kotlin 动态注册 Broadcast 的完整封装方案

在 Kotlin 中封装动态注册的 Broadcast 可以让你更优雅地管理广播的注册和注销,避免内存泄漏。下面是一个完整的封装方案: 基础封装类 import android.content.BroadcastReceiver import android.content.Context import android.content.Intent import …

VGG改进(8):融合Self-Attention的CNN架构

1. 自注意力机制简介自注意力机制是Transformer架构的核心组件,它能够计算输入序列中每个元素与其他所有元素的相关性。与CNN的局部感受野不同,自注意力机制允许模型直接建立远距离依赖关系,从而捕获全局上下文信息。在计算机视觉中&#xff…

ES6 面试题及详细答案 80题 (33-40)-- Symbol与集合数据结构

《前后端面试题》专栏集合了前后端各个知识模块的面试题,包括html,javascript,css,vue,react,java,Openlayers,leaflet,cesium,mapboxGL,threejs&…

PG-210-HI 山洪预警系统呼叫端:筑牢山区应急预警 “安全防线”

在山洪灾害多发的山区,及时、准确的预警信息传递是保障群众生命财产安全的关键。由 PG-210-HI 型号构成的山洪预警系统呼叫端主机,凭借其全面的功能、先进的特性与可靠的性能,成为连接管理员与群众的重要应急枢纽,为山区构建起一道…

研学旅游产品设计实训室:赋能产品落地,培养实用人才

1. 研学旅游产品设计实训室的定位与功能 研学旅游产品设计实训室是专门为学生提供研学课程与产品开发、模拟设计、项目推演、成果展示等实践活动的教学空间。该实训室应支持以下功能: 研学主题设计与目标制定; 课程内容与学习方法的选择与整合&#xf…

4215kg轻型载货汽车变速器设计cad+设计说明书

第一章 前言 3 1.1 变速器的发展环绕现状 3 1.2 本次设计目的和意义 4 第二章 传动机构布置方案分析及设计 5 2.1 传动机构结构分析与类型选择 5 2.2变速器主传动方案的选择 5 2.3 倒档传动方案 6 2..4 变速器零、部件结构方案设计 6 2.4.1 齿轮形式 …

9月10日

TCP客户端代码#include<myhead.h> #define SER_IP "192.168.108.179" //服务器&#xff49;&#xff50;地址 #define SER_PORT 8888 //服务器端口号 #define CLI_IP "192.168.108.239" //客户端&#xff49;&#xff50;地址 …

案例开发 - 日程管理 - 第七期

项目改造&#xff0c;进入 demo-schedule 项目中&#xff0c;下载 pinia 依赖在 main.js 中开启 piniaimport { createApp } from vue import App from ./App.vue import router from ./router/router.js import {createPinia} from pinialet pinia createPinia() const app …

infinityfree 网页连接内网穿透 localtunnel会换 还是用frp成功了

模型库首页 魔搭社区 fatedier/frp: A fast reverse proxy to help you expose a local server behind a NAT or firewall to the internet. 我尝试用本机ipv6&#xff0c;失败了 配置文件 - ChmlFrp 香港2才能用 只支持https CNAME解析 | 怊猫科技 | 文档 How to create …

批量更新数据:Mybatis update foreach 和 update case when 写法及比较

在平常的开发工作中&#xff0c;我们经常需要批量更新数据&#xff0c;业务需要每次批量更新几千条数据&#xff0c;采用 update foreach 写法的时候&#xff0c;接口响应 10s 左右&#xff0c;优化后&#xff0c;采用 update ... case when 写法&#xff0c;接口响应 2s 左右。…

Java基础篇04:数组、二维数组

1 数组 数组是一个数据容器&#xff0c;可用来存储一批同类型的数据。 1.1 数组的定义方式 静态初始化 数据类型[][] 数组名 {元素1&#xff0c;元素2&#xff0c;元素3}; string[][] name {"wfs","jsc","qf"} 动态初始化 数据类型[][] 数组名…

unity开发类似个人网站空间

可以用 Unity 开发 “个人网站空间” 类工具&#xff0c;但需要结合其技术特性和适用场景来判断是否合适。以下从技术可行性、优势、局限性、适用场景四个方面具体分析&#xff1a;一、技术可行性Unity 本质是游戏引擎&#xff0c;但具备开发 “桌面应用” 和 “交互内容” 的能…

SDK游戏盾如何实现动态加密

SDK游戏盾的动态加密体系通过​​密钥动态管理、多层加密架构、协议混淆、AI自适应调整及设备绑定​​等多重机制协同作用&#xff0c;实现对游戏数据全生命周期的动态保护&#xff0c;有效抵御中间人攻击、协议破解、重放攻击等威胁。以下从核心技术与实现逻辑展开详细说明&am…

TensorFlow平台介绍

什么是 TensorFlow&#xff1f; TensorFlow 是一个由 Google Brain 团队 开发并维护的 开源、端到端机器学习平台。它的核心是一个强大的数值计算库&#xff0c;特别擅长于使用数据流图来表达复杂的计算任务&#xff0c;尤其适合大规模机器学习和深度学习模型的构建、训练和部署…

TENGJUN防水TYPE-C连接器:立贴结构与IPX7防护的精密融合

在户外电子、智能家居、车载设备等对连接可靠性与空间适配性要求严苛的场景中&#xff0c;连接器不仅是信号与电力传输的“桥梁”&#xff0c;更需抵御潮湿、粉尘等复杂环境的侵蚀。TENGJUN防水TYPE-C连接器以“双排立贴”为核心设计&#xff0c;融合锌合金底座、精准尺寸控制与…