开源项目藏兵谷我的阅读

apidoc 生成 API 文档

2018-08-10  本文已影响172人  凯睿看世界

在开发接口的过程中,需要向外发布相应的接口文档。开始的时候使用word来写文档,时间长了发现有几个问题。1) 编写不方便。每次新增借口的时候都要复制上一个接口,然后再进行修改,一些相同的部分无法复用,接口多了文档会变的很长,还经常需要调整格式。2) 发布不方便。文档更新时,需要发给需要的小伙伴。即使用git来进行管理,虽然拉取比较方便,但由于文件格式的问题,也不方便比较两次提交的差异。

由于有这些问题,决定寻找一种更优雅有效的方式来编写文档。经过比较,发现了apidoc,可以比较好的解决上面提到的问题。apidoc采用了一种类似写代码注释的方式来写文档,支持编写多种语言的文档。最后生成的文档以网页的形式发布,方便快捷,便于阅读。下面就来简单介绍一下怎么使用apidoc来写文档。

     1.安装node

由于apidoc依赖node.js的包管理工具npm进行安装,所以安装apidoc之前要先安装node.js(npm会在安装node时顺带进行安装)。具体的安装教程可以参考这里

参考:

https://www.jianshu.com/p/9a6070565804

    2.安装apidoc

    安装完了npm之后,就可以安装apidoc了。在命令行输入

Shell代码

npm install apidoc -g  

     就可以进行安装了。安装完成输入

Shell代码

apidoc -h  

    出现相关的提示帮助信息,说明安装成功了。

    3 apidoc 常用注解介绍

    apidoc是运用各个不同的注解来完成文档的写作的。学习apidoc,主要就是学习注解的用法。apidoc和命名行的命令很像,由一个注解关键字加一些选项构成。下面介绍一下apidoc主要的注解。

Apidoc代码

@api {method} path [title]  

    这是apidoc必需的注解,用来说明api的方法,访问路径和作用。

Apidoc代码

@apiParam [(group)] [{type}] [field=defaultValue] [description]  

      这个注解用来说明api请求参数的类型,大小和作用。

Apidoc代码

@apiSuccess [(group)] [{type}] field [description]  

    这个注解说明api返回参数的类型,大小和作用。

关于注解的详细用法可以访问官网,上面有详细的用法和示例。

     4.编写apidoc文档

    了解了关于注解的用法之后,就可以用注解来编写文档了。例如我们可以编写一个GetUser.java文件。里面的内容如下所示:

Java代码

/**

 * @api {get} /user/:id Request User information

 * @apiGroup User

 *

 * @apiParam {Number} id Users unique ID.

 *

 * @apiSuccess {String} firstname Firstname of the User.

 * @apiSuccess {String} lastname  Lastname of the User.

 */

    5 生成apidoc文档

    编写完成后,运行

Shell代码

apidoc -i apidocIn -o apidocOut  

    apidocIn表示GetUser.java文件的存放目录,apidocOut表示希望apidoc文档生成的目录。运行成功后,在输   出目录可以看见一堆生成的文件,其中index.html是我们需要的文档。在浏览器打开就可以看见效果了。效果如下图所示:

注意:apidocIn是指要生成的java文件存放目录;apidocOut 是指生成文档的存放目录。而不是命令!!

     后面可以配置一下nginx,指定访问的路径映射到index.html,就可以让需要文档的小伙伴们访问了

其他相关apidoc的资料如下:

http://www.jianshu.com/p/bb5a4f5e588a

http://mp.weixin.qq.com/s?__biz=MzA4NzM4ODc4Ng==&mid=2647892810&idx=1&sn=7ed5866bb114e5a36a8d60c9bbc47b77&chksm=881d2457bf6aad4111dd04154b0d083b4486863fcdf10211694484074e1d4957886fbe5d2494&scene=0#rd

get hub地址:

https://github.com/apidoc/apidoc/tree/master/template

参考:https://blog.csdn.net/zhaoruifeng158/article/details/65445960

上一篇下一篇

猜你喜欢

热点阅读