我看到很多人提到MultiMarkdown对内部链接/命名锚的支持,但我找不到一个例子来说明如何做到这一点。

那么,表示命名锚的语法是什么,链接到它的语法是什么,与链接到任何其他url一样(只是使用#foo而不是http://....)?


当前回答

另一个选项(你可以把所有的链接放在文件的底部):

Here is an [example label].

  [example label]: #the-anchor-name-or-id "Optional title for mouse hover"

其他回答

创建内部链接(与sections相关)的最佳方法是创建list,但如果头文件包含空格,则放置#section或#section-title而不是link。

减价

Go to section
* [Hello](#hello)  
* [Hello World](#hello-world)
* [Another section](#new-section) <-- it's called 'Another section' in this list but refers to 'New section'


## Hello
### Hello World
## New section

列表预览

Go to section
Hello           <-- [Hello](#hello)                 -- go to `Hello` section
Hello World     <-- [Hello World](#hello world)     -- go to `Hello World` section
Another section <-- [Another section](#new-section) -- go to `New section`

HTML

<p>Go to section</p>
<ul>
    <li><a href="#hello">Hello</a></li>
    <li><a href="#hello-world">Hello World</a></li>
    <li><a href="#new-section">Another section</a> &lt;– it’s called ‘Another section’ in this list but refers to ‘New section’</li>
</ul>
<h2 id="hello">Hello</h2>
<h3 id="hello-world">Hello World</h3>
<h2 id="new-section">New section</h2>

不管它是h1, h2, h3等头文件,你总是使用一个#来引用它。 section list中的所有引用都应转换为小写文本,如上面的示例所示。

到section的链接应该是小写的。否则它不会起作用。这一技术适用于所有Markdown变体,也适用于MultiMarkdown。

目前我正在使用Pandoc转换文档格式。这比MultiMarkdown好多了。 在这里测试Pandoc

另一个选项(你可以把所有的链接放在文件的底部):

Here is an [example label].

  [example label]: #the-anchor-name-or-id "Optional title for mouse hover"

以下是我的解决方案(源自SaraubhM的答案)

**跳转到**:[热键&标记](#热键-标记)/ [Radii](# Radii) /[路由向导2.0](# Route - Wizard -2-0)

这就给了你:

跳转到:热键和标记/半径/路由向导2.0

注意和的变化。To -以及链接中&的缺失。

我测试了Github调味Markdown一段时间,可以总结出四个规则:

标点符号将被删除 前导空格将被删除 大写字母将转换为小写字母 字母之间的空格将转换为-

例如,如果你的section是这样命名的:

## 1.1 Hello World

这样创建一个链接:

[Link](#11-hello-world)

如果标记文件中有头文件,可以直接在文件中链接它们。

减价头:

## The Header

这将生成一个隐式的id #the-header(将内部空格替换为连字符并小写)。

要导航到这个id,你可以像这样创建链接:

[Link to Header](#the-header)

这相当于:

<a href="#the-header">Link to Header</a>

请注意引用的名称是小写的#头。