如果你正在使用 markdown 来编写 api 文档的话,API Blueprint 一定会成为你的更好的选择。
API Blueprint 是一套基于 markdown 的 API 描述语言规范,如果你按照它的规范来编写你的 API 文档的话,你就可以享受到配套的工具服务了。
语法与例子
学习 API Blueprint Language 非常简单, 只要你有用 markdown 写过东西, 那你一定能快速的掌握它.
首先, 查看官方提供的例子 . 一共也就 10 多个, 耐心看完. 心里就大概有数了.
然后可以看一下 语法规范 , 当前的稳定版本是 1A9。
官方的解释器 是完全支持 1A9 格式的。
有了这个解析器,就可以很容易的扩展自己的相关工具了(比如代码生成等)。
配套工具
编辑器插件
对于不熟悉语法的同学,强烈建议安装预览插件,相当于即时检查。
Mock 服务
两者都是可以根据 api-blueprint 的文档创建一个本地的 mock server 的工具。使用它们可以避免前后端开发在时间差上的无谓等待。
安装与使用都非常简单,确保本地装有 node 环境:
npm install -g api-mock
api-mock ./apiary.md --port 3000
npm install -g drakov
drakov -f apiary.md -p 3000
静态 HTML 生成
aglio 是一个可以根据 api-blueprint 的文档生成静态 HTML 页面的工具。
其生成的工具不是简单的 markdown 到 html 的转换, 而是可以生成类似 rdoc 这样的拥有特定格式风格的查询文档。
安装与使用都非常简单,确保本地装有 node 环境:
npm install -g aglio
aglio -i foo.md -o bar.html
Get Started
新建一个 hello.md
文件, 输入如下内容:
FORMAT: 1A
# Example API
hello world
## 消息 [/messages]
### 获取消息 [GET]
+ Response 200 (application/json)
{
"hello": "world"
}
然后试着
aglio -i hello.md -o hello.html
来看看生成的 html 文档.
再试试
api-mock ./hello.md --port 3000
或者
drakov -f ./hello.md -p 3000
访问 localhost:3000/message
是不是很酷, 不但有了漂亮的 html 文档, 也有了一个方便对接的 mock 服务.
如果配合 GitHub 或者自己搭建的 git 服务器,可以使用 hook 等方式自动化文档的发布。