Markdown 链接的写法

本文详细解析了Markdown中行内式和参考式链接的使用方法,包括语法细节、示例对比以及如何提升文档可读性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Markdown 支持两种形式的链接语法: 行内式和参考式两种形式。不管是哪一种,链接文字都是用 [方括号] 来标记。
1. 行内式
要建立一个行内式的链接,只要在方块括号后面紧接着圆括号并插入网址链接即可,如果你还想要加上链接的 title 文字,只要在网址后面,用双引号把 title 文字包起来即可

This is [an example](http://example.com/ "Title") inline link.

[This link](http://example.net/) has no title attribute.

会产生

<p>This is <a href="http://example.com/" title="Title">
an example</a> inline link.</p>

<p><a href="http://example.net/">This link</a> has no
title attribute.</p>

如果你是要链接到同样主机的资源,你可以使用相对路径

See my [About](/about/) page for details.

2. 参考式
参考式的链接是在链接文字的括号后面再接上另一个方括号,而在第二个方括号里面要填入用以辨识链接的标记

This is [an example][id] reference-style link.

你也可以选择在两个方括号中间加上一个空格

This is [an example] [id] reference-style link.

接着,在文件的任意处,你可以把这个标记的链接内容定义出来

[id]: http://example.com/  "Optional Title Here"

链接内容定义的形式为

  • 方括号(前面可以选择性地加上至多三个空格来缩进),里面输入链接文字
  • 接着一个冒号
  • 接着一个以上的空格或制表符
  • 接着链接的网址
  • 选择性地接着 title 内容,可以用单引号、双引号或是括弧包着
    下面这三种链接的定义都是相同:
[foo]: http://example.com/  "Optional Title Here"
[foo]: http://example.com/  'Optional Title Here'
[foo]: http://example.com/  (Optional Title Here)

注意:有一个已知的问题是 Markdown.pl 1.0.1 会忽略单引号包起来的链接 title。

链接网址也可以用方括号包起来

[id]: <http://example.com/>  "Optional Title Here"

你也可以把 title 属性放到下一行,也可以加一些缩进,若网址太长的话,这样会比较好看

[id]: http://example.com/longish/path/to/resource/here
    "Optional Title Here"

网址定义只有在产生链接的时候用到,并不会直接出现在文件之中。
链接辨别标签可以有字母、数字、空白和标点符号,但是并不区分大小写,因此下面两个链接是一样的

[link text][a]
[link text][A]

隐式链接标记功能让你可以省略指定链接标记,这种情形下,链接标记会视为等同于链接文字,要用隐式链接标记只要在链接文字后面加上一个空的方括号,如果你要让 “Google” 链接到 google.com,你可以简化成

[Google][]

然后定义链接内容

[Google]: http://google.com/

由于链接文字可能包含空白,所以这种简化型的标记内也许包含多个单词:

Visit [Daring Fireball][] for more information.

然后接着定义链接:

[Daring Fireball]: http://daringfireball.net/

链接的定义可以放在文件中的任何一个地方,我比较偏好直接放在链接出现段落的后面,你也可以把它放在文件最后面,就像是注解一样。

下面是一个参考式链接的范例

I get 10 times more traffic from [Google] [1] than from
[Yahoo] [2] or [MSN] [3].

  [1]: http://google.com/        "Google"
  [2]: http://search.yahoo.com/  "Yahoo Search"
  [3]: http://search.msn.com/    "MSN Search"

如果改成用链接名称的方式写

I get 10 times more traffic from [Google][] than from
[Yahoo][] or [MSN][].

  [google]: http://google.com/        "Google"
  [yahoo]:  http://search.yahoo.com/  "Yahoo Search"
  [msn]:    http://search.msn.com/    "MSN Search"

上面两种写法都会产生下面的 HTML。

<p>I get 10 times more traffic from <a href="http://google.com/"
title="Google">Google</a> than from
<a href="http://search.yahoo.com/" title="Yahoo Search">Yahoo</a>
or <a href="http://search.msn.com/" title="MSN Search">MSN</a>.</p>

下面是用行内式写的同样一段内容的 Markdown 文件,提供作为比较之用

I get 10 times more traffic from [Google](http://google.com/ "Google")
than from [Yahoo](http://search.yahoo.com/ "Yahoo Search") or
[MSN](http://search.msn.com/ "MSN Search").

参考式的链接其实重点不在于它比较好写,而是它比较好读,比较一下上面的范例,使用参考式的文章本身只有 81 个字符,但是用行内形式的却会增加到 176 个字元,如果是用纯 HTML 格式来写,会有 234 个字元,在 HTML 格式中,标签比文本还要多。

使用 Markdown 的参考式链接,可以让文件更像是浏览器最后产生的结果,让你可以把一些标记相关的元数据移到段落文字之外,你就可以增加链接而不让文章的阅读感觉被打断。

参考资料

Markdown 语法说明 (简体中文版)
Markdown链接及脚注

<think>嗯,用户想知道如何在Objective-C中使用Markdown创建表格。首先,我需要回忆一下Objective-C里处理文本和生成Markdown的方法。Objective-C本身并没有内置的Markdown库,但可以通过字符串拼接来实现。 首先,用户可能是在开发iOS或macOS应用,需要在应用中生成Markdown格式的内容,比如导出文档或者在富文本显示中使用。所以需要指导他们如何用NSString来构建表格的字符串结构。 接下来,Markdown表格的基本语法是使用竖线分隔列,连字符定义表头,然后对齐方式用冒号。比如: | 表头 | 表头 | |------|------| | 内容 | 内容 | 所以,在Objective-C中,可以创建一个方法,接收数据数组,然后循环拼接成这样的字符串。需要注意转义字符和换行符的使用,比如每个行末尾加上\n。 然后,考虑到用户可能需要动态生成表格,比如从数据模型或数组中获取内容,应该建议他们编写一个工具方法,将二维数组转换成Markdown表格字符串。例如,传入一个NSArray的数组,包含表头和各行数据,然后遍历每个元素,用|连接,并在表头下方添加分隔行。 另外,引用中提到MarkdownKit可以将Markdown转换为富文本,可能用户需要显示表格在UI上,比如UITextView或UILabel,这时候可以结合MarkdownKit来解析生成的Markdown表格,使其显示为格式化的内容。因此需要提到如何结合使用生成的Markdown字符串和MarkdownParser类。 还需要注意代码示例的正确性,比如使用NSMutableString来拼接字符串,处理表头和数据行的循环,以及对齐方式的设置。可能用户对对齐方式有疑问,所以示例中要包含左对齐、居中对齐和右对齐的写法,但Markdown中默认是左对齐,分隔符用:---、:---:、---:来分别表示左、中、右对齐。 最后,确保回答结构清晰,分步骤说明,并给出示例代码。同时,相关问题要引导用户深入,比如优化表格生成、处理复杂内容或与其他语法结合使用。</think>在Objective-C中实现Markdown表格,可以通过字符串拼接的方式生成符合Markdown语法的文本。以下是具体实现步骤和示例: ### 一、Markdown表格语法基础 Markdown表格使用竖线`|`分隔列,连字符`-`定义表头分隔线: ```markdown | 姓名 | 年龄 | 性别 | |------|-----:|:----:| | 张三 | 25 | 男 | | 李四 | 30 | 女 | ``` - 对齐方式通过冒号控制:`:---`左对齐,`:---:`居中对齐,`---:`右对齐[^2] ### 二、Objective-C实现方法 #### 1. 基础字符串拼接 ```objective-c NSMutableString *markdownTable = [NSMutableString new]; [markdownTable appendString:@"| 姓名 | 年龄 | 性别 |\n"]; [markdownTable appendString:@"| :--- | ---: | :---: |\n"]; [markdownTable appendString:@"| 张三 | 25 | 男 |\n"]; [markdownTable appendString:@"| 李四 | 30 | 女 |"]; ``` #### 2. 动态生成工具方法 ```objective-c - (NSString *)generateMarkdownTableWithHeaders:(NSArray<NSString *> *)headers rows:(NSArray<NSArray<NSString *> *> *)rows { NSMutableString *table = [NSMutableString new]; // 生成表头 [table appendFormat:@"| %@ |\n", [headers componentsJoinedByString:@" | "]]; // 生成分隔线 NSMutableArray *separators = [NSMutableArray new]; for (NSInteger i = 0; i < headers.count; i++) { [separators addObject(@"---")]; } [table appendFormat:@"| %@ |\n", [separators componentsJoinedByString:@" | "]]; // 生成数据行 for (NSArray *row in rows) { [table appendFormat:@"| %@ |\n", [row componentsJoinedByString:@" | "]]; } return [table copy]; } ``` ### 三、与MarkdownKit结合使用 通过MarkdownParser可将生成的表格转换为富文本: ```objective-c NSString *markdown = [self generateMarkdownTableWithHeaders:@[@"ID", @"Name"] rows:@[@[@"1", @"Alice"], @[@"2", @"Bob"]]]; MarkdownParser *parser = [MarkdownParser new]; NSAttributedString *attributedText = [parser parse:markdown]; textView.attributedText = attributedText; // 在UITextView中显示 ``` ### 四、注意事项 1. 特殊字符需转义处理:`|`应转换为`\|` 2. 建议每列内容不超过屏幕宽度 3. 复杂表格建议使用第三方库如[MMMarkdown](https://github.com/mdiep/MMMarkdown)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值