DocFX 入门

  1. DocFX 是什么?

DocFX 是一个基于.NET的API文档生成器,当前支持 C# 和 VB。

它可以通过你的代码中的三斜杠注释生成 API 参考文档。同样也支持你使用 Markdown 文件创建一些其他的主题文档(例如:教程以及使用手册)。以及自定义生成的参考文档。

DocFX 会使用你的代码以及 Markdown 文件生成一个静态的 HTML 网站。你可以将它轻松的部署到任何web 服务器(例如: github.io)。同样的 DocFX 也提供扩展性,允许你通过模版自定义网站的布局和样式.

如果你有兴趣使用你自己的样式创建你的网站,你可以参考 如何创建自定义模版 来创建你的自己的模版。

DocFX 还包含以下很酷的功能:

  • 和你的代码紧密集成。你可以在文档中点击 "View Source" 链接导航到github上对应的源代码(你的代码必须发布到 GitHub )。
  • 跨平台的支持。拥有Windows平台以及.NET Core 的跨平台 exe程序。
  • 和Visual Studio集成. 你可以在Visual Studio 中无缝使用 DocFX
  • Markdown 扩展。我们推荐DocFX Flavored Markdown(DFM) 格式来编写文档。 DFM 100% 兼容 GitHub Flavored Markdown(GFM) 并且添加了一些有用的扩展,例如 file inclusion文件包含), code snippet代码片段), cross reference交叉引用), 以及 yaml header

    更多关于 DFM 的信息, 请参考 DFM



2. 使用 DocFX 命令行工具

第1步. DocFX 被打包成 chocolatey 包.

可以通过 Chocolatey 调用命令 cinst docfx -y 来安装。

另外, 你也可以从https://github.com/dotnet/docfx/releases 下载docfx.zip文件, 并解压到本地目录, 把程序路径添加到 PATH 环境变量这样你可以在任何环境调用它。

第2步. 创建实例项目

docfx init -q

命令行会生成一个名为 docfx_project 的默认项目。

第3步. 编译网站

docfx docfx_project\docfx.json --serve

现在可以通过访问 http://localhost:8080 浏览生成网站了.

  1. 在 Visual Studio 中集成DocFX

Step2. 编译项目, 项目里面会生成一个 _site 文件夹。

[!注意]

可能会出现的警告:

  • Cache is corrupted:如果项目目标是多framework, 你不得不为文档指定一个主framework, 通过设置 docfx.json 文件的 TargetFramework 属性

[!NOTE]
> *Possible warning*:
> - *Cache is corrupted*: if your project targets multiple frameworks, you have to indicate one to be the main for the documentation, through the [`TargetFramework` property](https://github.com/dotnet/docfx/issues/1254#issuecomment-294080535) in `docfx.json`: -->

 "metadata": [
{
"src": "...",
"dest": "...",
"properties": {
"TargetFramework": <one_of_your_framework>
}
},
]
  1. 使用DocFX 生成服务

DocFX 可以在持续集成环境中使用。

大部分编译系统不会检查分支是否被生成,但是如果使用 detached head 来指定提交,DoxFX 需要分支名赖在api 文档中实现 View Source 链接。

设置 DOCFX_SOURCE_BRANCH_NAME 环境变量告知 DocFX 使用哪个分支。

需要编译系统支持分支名环境变量. DocFX 使用以下变量:

[!注意]

AppVeyor 已知问题: 当前 appveyor.yml 中的配置 platform: Any CPU 会导致 docfx metadata 失败。 https://github.com/dotnet/docfx/issues/1078

[!NOTE]
> *Known issue in AppVeyor*: Currently `platform: Any CPU` in *appveyor.yml* causes `docfx metadata` failure. https://github.com/dotnet/docfx/issues/1078 -->

  1. 从源代码生成

作为前置条件, 你必须具备:

第1步. git clone https://github.com/dotnet/docfx.git 获取最新代码。

第2步. 运行根目录下的 build.cmd

第3步. 在IDE的 nuget 源中增加 artifacts 目录:

Tools > NuGet Package Manager > Package Manager Settings > Package Sources

Tools > NuGet Package Manager > Package Manager Settings > Package Sources -->

Step4. 按照之前的 #2, #3, #4 步骤在命令行,IDE 或者.NET Core中使用 DocFX

  1. DocFX 种子项目要

这里有一个种子项目 https://github.com/docascode/docfx-seed. 包含

  1. src 目录中有个基本的 C# 项目。
  2. articles 目录中有一些说明文档。
  3. 一个可覆盖的文件,在“specs”下添加额外的内容到API
  4. 根目录下的 toc.yml 文件。生成网站的导航栏。
  5. 根目录下的 docfx.json 文件。 docfx 的配置文件。

<!-- 6. A seed project to play with DocFX

Here is a seed project https://github.com/docascode/docfx-seed. It contains

  1. A basic C# project under src.
  2. Several conceptual files under articles.
  3. An overwrite file to add extra content to API under specs.
  4. toc.yml under root folder. It renders as the navbar of the website.
  5. docfx.json under root folder. It is the configuration file that docfx depends upon. -->

[!提示]

将不同类型的文件放入不同的目录是一个好习惯。

[!Tip]
> It is a good practice to separate files with different type into different folders. -->

  1. Q&A

  1. Q: 如何在api中快速引用其他 API 或者 c?

    A: Use @uid syntax.
  2. Q: uid 是什么,我怎么去找 uid?

    A: 参考 DFM 交叉引用 章节。
  3. Q: 如何在网站中快速找到 uid ?

    A: 在生成网站中, 点击 F12 查看源代码,查看API标题. 你会在data-uid标签中找到 uid

<!-- 7. Q&A

  1. Q: How do I quickly reference APIs from other APIs or c?

    A: Use @uid syntax.
  2. Q: What is uid and where do I find uid?

    A: Refer to Cross Reference section in DFM.
  3. Q: How do I quickly find uid in the website?

    A: In the generated website, hit F12 to view source, and look at the title of an API. You can find uid in data-uid attribute. -->

【DocFX文档翻译】DocFX 入门 (Getting Started with DocFX)的更多相关文章

  1. Kinect帮助文档翻译之一 入门

    最近在玩Kinect,使用的是Unity,发现网上好像没有什么教程.自己就只有抱着英文版帮助文档啃,真是苦逼 本人英语也不好,大家将就着看吧 Kinect入门帮助 如何运行示例 1       下载并 ...

  2. Docker官方文档翻译之入门

    转自:http://www.cnblogs.com/vikings-blog/p/3958091.html Docker学习总结之docker入门 Understanding Docker 以下均翻译 ...

  3. TensorFlow文档翻译-01-TensorFlow入门

    版权声明:本文为博主原创文章,转载请指明转载地址 http://www.cnblogs.com/junyang/p/7429771.html TensorFlow入门 英文原文地址:https://w ...

  4. React文档翻译 (快速入门)

    翻译自react的大部分文档,方便自己查阅. 目录 生命周期 实例化 存在期 销毁期 state Do Not Modify State Directly State Updates May Be A ...

  5. 使用DocFX生成文档

    使用DocFX命令行生成文档 使用docfx 命令 1.下载 https://github.com/dotnet/docfx/releases 2.使用 创建初始项目 docfx init -q 此命 ...

  6. docfx (一)

    什么是docFX? DocFX 是一个基于.NET的API文档生成器,当前支持 C# 和 VB.它可以通过你的代码中的三斜杠注释生成 API 参考文档.同样也支持你使用 Markdown 文件创建一些 ...

  7. DocFX生成PDF文档

    使用DocFX生成PDF文档,将在线文档转换为PDF离线文档. 关于DocFX的简单介绍使用DocFX生成文档 使用docfx 命令 1.下载 https://github.com/dotnet/do ...

  8. docfx chocolatey安装方法

    这两天在git下载的docfx.zip .在安装过程中总是闪退,而加入环境变量后,执行提示:config file  docfx.json does not exist.所以我选择chocolatey ...

  9. 使用 DocFX 生成 .Net/Unity项目文档

    孙广东  2017.5.27 http://blog.csdn.NET/u010019717 微软开源全新的文档生成工具DocFX   类似JSDoc或Sphinx     如何使用看 : http: ...

随机推荐

  1. python note 17 random、time、sys、os模块

    1.random模块(取随机数模块) # 取随机小数 : 数学计算 import random print(random.random())# 取0-1之间的小数 print(random.unifo ...

  2. linux下查看动态链接库so文件的依赖的相关组建

    我们很多c程序在windows下是以dll形式展现的,在linux则是以so 形式展现的. windows一般不会因为编译dll文件的编译器版本不同而出先dll文件不能执行. 但是linux下,不同版 ...

  3. Codeforces Round #552 (Div. 3) B题

    题目链接:http://codeforces.com/contest/1154/problem/B 题目大意:给出n个数,每个数都可以加上或减去这个一个数D,求对这n个数操作之后当所有数都相等时,D的 ...

  4. UIButton设置UIControlContentHorizontalAlignment调整文字对齐方式

    UIButton 继承自UIControl,所以可以对UIControlContentHorizontalAlignment进行设置 btn.setImage(UIImage.init(named: ...

  5. VirtualBox 桥接模式,虚拟机ping不通宿主机

    虚拟机为window server 2012 参考链接:https://blog.csdn.net/Leon_190/article/details/84937045#commentBox 该做的都做 ...

  6. c#Dapper mysql按时间段查询和过滤

    #endregion /// <summary> /// 根据条件获取集合 /// </summary> /// <param name="id"&g ...

  7. Layui 写一个简单的后台页面

    参考如下: 1.layui 官方文档 http://www.layui.com/doc/ 2.https://blog.csdn.net/huyanliang/article/details/7796 ...

  8. python生成器 获取 目录下文件

    # os.walk()和os.list 都是得到所有文件的列表, 如果目录下文件特别多, 上亿了, 我们就需要生成器的方式获取 # 要求目录下面没有目录, 会递归到子目录下面找文件, (如果有子目录可 ...

  9. Finance财务软件(自定义报表专题)

    我们可以通过存储过程自定义报表 1.在菜单中新增报表菜单,这里的代码约束为报表对应存储过程名称,配置完成成后重启客户端生效 2.在自定义模板中适配存储过程入参,这里的功能键值为存储过程名称,字段键值与 ...

  10. vue版 文件下载

    标签的download: 是HTML5标准新增的属性,作用是指示浏览器下载URL而不是导航到URL,因此将提示用户将其保存为本地文件. 这种是定义的接口不是下载文件的路径,而是通过API可以获得文件的 ...