是否可以使用Github调味Markdown自动生成目录?
GitHub Pages(它基本上是Jekyll的包装器)似乎使用了kramdown,它实现所有Maruku,因此通过__abc0属性支持自动生成的目录:
* auto-gen TOC: {:toc}
第一行只是开始一个无序列表,实际上被丢弃了。
这将使用文档中的头文件生成一组嵌套的无序列表。
注意:这应该适用于GitHub页面,而不是在评论或wiki页面中使用的GitHub调味Markdown (GFM)。我想这个问题没有解决办法。
:with_toc_data -添加HTML锚到输出HTML中的每个头, 允许链接到每个节
似乎你需要在渲染器级别设置这个标志,这在Github上显然是不可能的。然而,最新更新到Github页面,似乎自动锚定是为标题打开的,创建可链接的标题。这不是你想要的,但它可能会帮助你更容易地为你的文档创建一个TOC(尽管是手动的)。
我创建了两个选项来生成一个toc的github风味markdown:
npm install -g doctoc
doctoc .为当前目录和所有子目录中的所有markdown文件添加目录。
doctoc .
正如Matthew Flaschen在下面的评论中指出的那样,对于它的维基页面,GitHub之前没有生成doctoc所依赖的锚。
doctoc
更新:但是,他们修复了这个问题。
使用http://documentup.com/从README.md文件自动生成网页是可能的。它不是创建TOC,但对于许多人来说,它可能解决了想要创建TOC的原因。
README.md
Documentup的另一个替代方案是Flatdoc: http://ricostacruz.com/flatdoc/
它不是自动的,但它使用notepad++正则表达式:
用第二个替换所有第一个(删除所有没有标题的行)
^##(#?)(#?)(.*?)$(.|\r|\n)*?(?=^##|\z) -\1\2 [\3](#\3)\n
然后(将头III转换为空格)
-## -
然后(将标题II转换为空格)
-# -
然后(删除链接标题开头和结尾未使用的字符)
\[ *((?:(?![ .:#!\?;]*\])[^#])*)[ #:!\?;]*\] [\1]
然后(转换最后一个符号小写和破折号而不是空格)
\]([^ \r\n]*) ([^\r\n ]*) ]\L\1-\2
删除未使用的最后磅和初始破折号:
(?:()[-:;!\?#]+$|(\]#)-) \1\2
删除链接中无用的字符:
(\].*?)(?:\(|\)) \1
最后在最后链接的周围加上圆括号:
\](?!\()(.*?)$ \]\(\1\)
瞧!如果你重复足够多的时间,你甚至可以把它放在一个全局宏中。
2021年3月更新:GitHub增加了一个官方解决方案
readme现在显示一个ToC,就像你向下滚动它们:
演示:https://github.com/cirosantilli/test-git-web-interface/tree/master/d
它没有在文档中呈现,因为我想要更好的Ctrl + F,但总比没有强。
Also现在也适用于非readme,例如:https://github.com/cirosantilli/test-git-web-interface/blob/master/md.md
他们还添加了一个存储库设置来启用禁用该功能。太奇怪了,谁会想让它失效呢?在https://github.com/cirosantilli/test-git-web-interface/settings特性下:
目录 自动生成此存储库中Markdown文件的目录。目录将显示在文件顶部附近。
目录
自动生成此存储库中Markdown文件的目录。目录将显示在文件顶部附近。
原来的答案
这是不可能的,除了建议的变通办法。
我提出了 Kramdown TOC扩展和其他可能性support@github.com和史蒂文!世界毁灭回复通常:
谢谢你的建议和链接。我将把它添加到我们的内部功能请求列表中,供团队查看。
让我们给这个问题投票,直到它发生为止。
另一个解决方法是使用Asciidoc代替Markdown, 哪个渲染toc。现在我的内容已经采用了这种方法。
使用coryfklein / doctoc,它是thlorenz / doctoc的一个分支,不会将"生成与 DocToc"添加到每个目录中。
npm install -g coryfklein/doctoc
Gitdown是一个用于Github的markdown预处理器。
使用Gitdown你可以:
giitdown简化了与维护GitHub存储库文档页面相关的常见任务。
使用它很简单:
var Gitdown = require('gitdown'); Gitdown // Gitdown flavored markdown. .read('.gitdown/README.md') // GitHub compatible markdown. .write('README.md');
你既可以把它作为一个单独的脚本,也可以把它作为构建脚本例程的一部分(比如狼吞虎咽地吃)。
我的同事@schmiedc和我已经创建了一个GreaseMonkey脚本,它在h1按钮的左边安装了一个新的TOC按钮,该按钮使用优秀的markdown-js库来添加/刷新目录。
h1
TOC
markdown-js
与docc等解决方案相比,其优势在于它集成到GitHub的wiki编辑器中,不需要用户使用命令行(并要求用户安装node.js等工具)。在Chrome中,它通过拖拽到扩展页面来工作,在Firefox中,你需要安装GreaseMonkey扩展。
node.js
它将与普通markdown工作(即它不能正确处理代码块,因为这是一个GitHub扩展markdown)。贡献的欢迎。
如果你用Vim编辑Markdown文件,你可以试试这个插件vim-markdown-toc。
使用方法很简单,只需将光标移动到你想要添加目录表的位置并运行:GenTocGFM,完成!
:GenTocGFM
截图:
特点:
为Markdown文件生成toc。(支持GitHub调味Markdown和Redcarpet)
更新现有的toc。
保存时自动更新toc。
这并不是对这个问题的直接回答,因为很多人都提供了变通方法。我认为到目前为止,Github还没有正式支持生成TOC。如果你想要GitHub在他们的GFM预览页面上自动呈现一个目录,请参加官方特性请求问题上的讨论。
目前它是使用markdown语法的不可能的(参见正在进行的在GitHub讨论),但是你可以使用一些外部工具,例如:
或者使用AsciiDoc代替(例如README.adoc)。
AsciiDoc
README.adoc
:toc: macro :toc-title: :toclevels: 99 # Title ## A ### A2 ## B ### B2
如评论所示。检查演示在这里。
对于Github的Texteditor Atom . io/" rel="nofollow noreferrer">Atom . io/" rel="nofollow noreferrer,请查看这个很棒的插件(或atom术语中的“包”),它会生成“从解析markdown标题的TOC(目录)”文件:
markdown-toc
一旦安装为Atom-package,您可以使用快捷方式ctrl-alt-c在当前光标位置插入基于markdown-doc-structure的TOC…
ctrl-alt-c
原子键
markdown-toc为您提供以下默认键绑定来控制Atom中的插件:
ctrl-alt-u
ctrl-alt-r
插件的功能(来自项目的README)
# A 1
#a-1
depthFrom:1
depthTo:6
withLinks:1
updateOnSave:1
orderedList:0
在使用Visual Studio Code时,实现mardown文件目录的非常方便的方法是扩展名Markdown-TOC。
它可以向现有的markdown文件添加toc,甚至在保存时保持toc的最新状态。
下面是我今天为此编写的shell脚本。可能需要根据你的需要进行调整,但这应该是一个很好的起点。
cat README.md \ | sed -e '/```/ r pf' -e '/```/,/```/d' \ | grep "^#" \ | tail -n +2 \ | tr -d '`' \ | sed 's/# \([a-zA-Z0-9`. -]\+\)/- [\1](#\L\1)/' \ | awk -F'(' '{for(i=2;i<=NF;i++)if(i==2)gsub(" ","-",$i);}1' OFS='(' \ | sed 's/^####/ /' \ | sed 's/^###/ /' \ | sed 's/^##/ /' \ | sed 's/^#//'
如果有人知道更好的方法来做这些最终的#替换,请添加评论。我尝试了各种各样的方法,但都不满意,所以我就硬着硬着。
现在有一个GitHub行动完成这一点:
https://github.com/marketplace/actions/toc-generator
<!-- START doctoc --> <!-- END doctoc -->
.github/workflows/toc.yml
on: push name: TOC Generator jobs: generateTOC: name: TOC Generator runs-on: ubuntu-latest steps: - uses: technote-space/toc-generator@v2
大多数其他答案需要安装一些工具。 我找到了一个快速简单的在线解决方案< a href = " https://imthenachoman.github。io/nGitHubTOC" rel="nofollow noreferrer">https://imthenachoman.github.io/nGitHubTOC。
对于任何markdown输入,它生成内容输出表。 您可以指定最小和最大标题级别
源代码位于https://github.com/imthenachoman/nGitHubTOC
更新2022 - 02年
在VSCode中,查看扩展“Markdown All In one”。自动生成并更新减记的TOC。
无耻的“borrow"这个SO答案。
你可以用Pandoc来实现。
pandoc -s --toc input.md -o input_toc.md
注意:输入和输出文件的顺序在这里很重要。