向下工作法的一点思考:文档即代码

2018-07-20 07:36:46 +08:00
 banxi1988

2006 的时候,amazon CTO 在一篇文章中介绍了向下工作法(或者有也有翻译成向后工作法)

https://www.allthingsdistributed.com/2006/11/working_backwards.html

向下工作法,简而言之就是下面的流程:

  1. 先写宣传稿
  2. 再写 FAQ
  3. 再定义用户体验
  4. 再写用户手册

走完这 4 步之后,对于要做的产品应该是相当的清晰了。

我看了之后深以为然。

然后分享我的一个思考:文档即代码

这一点对于前后端 API 模块的开发来说相当适用。 也就是说,正确良好的工作过程应该是,先写好 API 文档,再通过 API 文档生成前端的 JS/TS 代码。 通过 API 文档生成后端代码。

前后端的 API 模块都应该遵从这样一个逻辑。

  1. 先写 API 文档。
  2. 通过 API 文档生成 代码,(需要时初始手写代码)
  3. 更新 API 文档
  4. 再根据 API 文档更新前后端代码。
  5. ...

它带来的好处:

  1. API 文档和前后端的代码,能保持高度一致
  2. 通过代码自动生成基本的代码,减少工作量(大部分的 Domain Model, 和 基本 API 接口请求及响应都应该自动生成)
  3. 方便批量修改。

API 文档可以采用 Swagger 的文档。

5723 次点击
所在节点    程序员
24 条回复
specita
2018-07-20 12:15:33 +08:00
理想很美好,现实.... 首先你得有一群能实践你想法的队友...
shyangs
2018-07-20 13:03:42 +08:00
老外就没遇过需求都讲不清楚,说明天要验收的 PM 呀

::doge::
mcfog
2018-07-20 13:18:57 +08:00
个人更倾向反过来,代码生成文档,毕竟让程序员写代码和让程序员写文档的难度差了不止一个数量级
A555
2018-07-20 14:29:24 +08:00
客户:虽然我想做什么都不知道,但是你必须要满足我。
我我不知道我要做成什么样啊,不然我找你们干嘛

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/472532

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX