Skip to content

Latest commit

 

History

History
160 lines (99 loc) · 9.46 KB

CONTRIBUTING.md

File metadata and controls

160 lines (99 loc) · 9.46 KB

参与 ASP.NET Core 文档

本文档介绍了参与到 ASP.NET 文档站点上托管的文章和代码示例中的过程。 欢迎更正拼写错误以及撰写新文章。

如何提出简单的更正或建议

文章作为 Markdown 文件存储在存储库中。 通过选择浏览器窗口右上角的“编辑”链接,可以在浏览器中对 Markdown 文件的内容进行简单更改。 (在窄浏览器窗口中,展开“选项”栏,以查看“编辑”链接 。)按照说明创建拉取请求 (PR)。 我们将对拉取请求进行评审并接受相关请求或提出更改建议。

如何提出更复杂的提交

需要对 Git 和 GitHub.com 有基本的理解。

  • 创建一个问题,描述你想要执行的操作,例如更改现有项目或创建一个新项目。 我们经常要求提供新主题建议的大纲。 请等待团队批准后再投入时间参与进来。
  • aspnet/Docs 存储库创建分支,并为所做出的更改创建一个分支。
  • 将所做更改随着 PR 一起提交到 分支。
  • 如果拉取请求分配的标签为 “cla-required”,则完成贡献许可协议 (CLA)
  • 对 PR 请求反馈进行响应。

有关此过程引导发布新文章的示例,请参阅 .NET Docs 存储库中的问题 1477拉取请求 18955。 新文章是将代码覆盖率用于单元测试

Visual Studio Code 中的 Docs 创作包扩展

如果使用 Visual Studio Code 参与到 ASP.NET 文档中,可以通过安装 Docs 创作包扩展来提高工作效率。 该扩展提供各种有助于 Markdown 语法检查、代码拼写检查和项目模板的工具。

Markdown 语法

文章采用 DocFx 风格的 Markdown 编写,它是 GitHub 风格的 Markdown (GFM) 的超集。 有关 ASP.NET 文档中常用的 UI 功能的 DFM 语法示例,请参阅 .NET Docs 存储库风格指南中的元数据和降价模板

文件夹结构约定

对于每个Markdown 文件,可能存在图像文件夹和示例代码文件夹。 如果文章是 fundamentals/configuration/index.md,则图像位于 fundamentals/configuration/index/_ 中,示例应用项目文件位于 fundamentals/configuration/index/sample 中。 fundamentals/configuration/index.md 文件中的图像由以下 Markdown 呈现:

![description of image for alt attribute](configuration/index/_static/imagename.png)

所有图像都应具有替代 (alt) 文本。 有关指定替代文本的建议,请参阅在线资源,例如 WebAIM:替代文本

Markdown 文件名称和图像文件名称使用小写。

内部链接

内部链接应使用目标文件的 uid 和外部参照链接(链接文本设置为链接内容的标题):

<xref:uid_of_the_topic>

如果文章标题不适合用于链接文本(例如,句子中的单词或短语是链接文本),请使用以下内容指定外部参照链接和链接文本:

[link text](xref:uid_of_the_topic)

有关详细信息,请参阅 DocFX 交叉引用.

图像和屏幕截图

请勿在文章中包含图像,除非:

  • 在基本的入门(初级)教程中。
  • 需要图像辅助说明。

这些限制可缩小存储库的大小。

作为可选步骤,请确保文档中使用的任何图像和屏幕截图都已压缩,这有助于缩小文件大小和提高页面加载性能。 几个常用工具包括 TinyPNG (使用 TinyPNG 网站TinyPNG API)或图像优化器 Visual Studio 扩展。

代码片段

文章经常使用代码片段来说明要点。 DFM 允许将代码复制到 Markdown 文件或引用单独的代码文件。 请尽可能使用单独的代码文件,以最大限度地减少代码中出错的可能性。 代码文件存储在使用前面示例项目所述的文件夹结构的存储库中。

以下示例说明了用于 configuration/index.md 文件的 DFM 代码片段语法

将整个代码文件呈现为代码片段:

[!code-csharp[](configuration/index/sample/Program.cs)]

使用行号将文件的一部分呈现为代码片段:

[!code-csharp[](configuration/index/sample/Program.cs?range=1-10,20,30,40-50]
[!code-html[](configuration/index/sample/Views/Home/Index.cshtml?range=1-10,20,30,40-50]

有关 C# 代码段,请参阅 C# 区域。 请尽可能使用区域而不是行号,因为代码文件中的行号往往会更改,并与 Markdown 中引用的行号不同步。 可嵌套 C# 区域。 如果要引用外部区域,内部 #region#endregion 指令不会呈现在代码段中。

呈现名为 “snippet_Example” 的 C# 区域:

[!code-csharp[](configuration/index/sample/Program.cs?name=snippet_Example)]

突出显示呈现的代码段中选定的行(通常呈现为黄色背景):

[!code-csharp[](configuration/index/sample/Program.cs?name=snippet_Example&highlight=1-3,10,20-25)]
[!code-csharp[](configuration/index/sample/Program.cs?range=10-20&highlight=1-3]
[!code-html[](configuration/index/sample/Views/Home/Index.cshtml?range=10-20&highlight=1-3]
[!code-javascript[](configuration/index/sample/UsingOptionsSample.csproj?range=10-20&highlight=1-3]

使用 DocFX 测试更改

使用 DocFX 命令行工具测试更改,这将创建站点的本地托管版本。 DocFX 不呈现为 docs.microsoft.com 创建的样式和站点扩展。

DocFX 要求:

  • Windows 上的 .NET Framework。
  • 适用于 Linux 或 macOS 的 Mono。

Windows 说明

  • DocFX 发布下载并解压缩 “docfx.zip”。

  • 将 DocFX 添加到路径。

  • 在命令行界面,导航到包含 docfx.json 文件的文件夹(ASP.NET 内容为 aspnet 或 ASP.NET Core 内容为 aspnetcore),并运行以下命令:

    docfx --serve
  • 在浏览器中导航到 http://localhost:8080/group1-dest/

Mono 说明

  • 使用 Homebrew 安装 Mono:

    brew install mono
  • 下载 DocFX 的最新版本

  • 将存档提取到 $HOME/bin/docfx。

  • 在 Bash Shell 中为 docfx 创建一对别名。 第一个别名用于生成文档。 第二个别名用于生成和提供文档。

    alias docfx='mono $HOME/bin/docfx/docfx.exe'
    alias docfx-serve='mono $HOME/bin/docfx/docfx.exe --serve'
  • 在命令行界面,导航到包含 docfx.json 文件的文件夹(ASP.NET 内容为 aspnet 或 ASP.NET Core 内容为 aspnetcore),并运行以下命令通过其别名构建和提供文档:

    docfx-serve
  • 在浏览器中导航到 http://localhost:8080/group1-dest/

语音和声调

我们的目标是编写被广泛受众所理解的易懂文档。 为此,我们编写了写作风格指南,请参与者遵守。 有关详细信息,请参阅 .NET 存储库中的 语气和语调指南

Microsoft 编写风格指南

Microsoft 编写风格指南提供的编写风格和术语指南适用于所有形式的技术交流(包括 ASP.NET Core 文档)。

重定向

如果删除某篇文章、更改文章的文件名或将其移到另一个文件夹,请创建一个重定向,确保将此项目收藏为书签的人不会收到 404 Not Found 错误。 向主重定向文件添加添加重定向。