一些Markdown扩展语法
相信很多人跟我一样,对Markdown是“一知半解”,会打一点,知道一点,但是其实从没花哪怕一分钟了解过。其实除了标题粗体插入代码,Markdown还有很多有趣的基础语法和扩展语法。
Markdown基本语法就是由 John Gruber 最初设计的语法(如标题,加粗,斜体等),它很简单且很常用,但是功能相当有限。由于一直没有Markdown的确定标准,各个平台自制的“民间Markdown”应运而生,扩展语法增加了许多高级的功能(表格,角标等),可以实现更多功能。各个地方的扩展语法不尽相同。在一些网络平台或者本地编辑器上有效的语法,可能在其他地方并不能正确显示。不过对于一些最常见的扩展语法,各个地方还是大致统一的。
表格(Tables)
大家应该都用过自动生成的Markdown表格,事实上自己打也并不复杂。Markdown支持创建任意mxn表格,并且可以对每一列设置对齐方式
|中国|美国|日本|韩国|
|-:|-|:-:|:-:|
|北京|华盛顿|东京|首尔|
|`1450000000`|327000000|126300000|52000000|
中国 | 美国 | 日本 | 韩国 |
---|---|---|---|
北京 | 华盛顿 | 东京 | 首尔 |
1450000000 |
327000000 | 126300000 | 52000000 |
一个mxn表格由m+1行构成,其中第一行是表头,第二行指定对齐方式(Alignment),之后所有的行是剩余的行。每一行由n+1个分隔符|
分割为n格,每一格储存该列的信息。不同列的长度可以不同,无需对齐,这一列会自动调整宽度,完整显示一列里最宽的数据。列里的数据也支持简单的语法
上面的代码创建了一个3x4的表格。观察第二行的对齐方式。可以发现:
---:
表示向右对齐(-
可以有任意多个,下同):--:
表示向中对齐:--
或--
(即默认值)表示向左对齐
列表,引用的嵌套(Nested List & Quotation)
不算扩展的语法,但是很有意思。Markdown中有序或无序列表的嵌套规则是以缩进(Indent)来决定
1. First
- Indent1
- Indent2
2. Second
1. Indent1
2. Indent2
- First
- Indent1
- Indent2
- Second
- Indent1
- Indent2
实际上,要在任何列表间插入其他内容,都可以不用打断列表,在列表的两项之间缩进就可以,列表的顺序和结构是完全由缩进来决定的
1. First
> Quotation in First
2. Second
- First
Quotation in First
- Second
而引用的嵌套只有大于号的个数决定,几个大于号就是几层嵌套,甚至一级引用里可以直接出现三级引用。同一级引用会在引用框左边自动连接。
> line1
> > line2
> > > line3
>
> line4
> line5
> > > line6
line1
line2
line3
line4
line5line6
注意引用内的文字也需要多打一个回车才能分开,否则可能会显示在一行(这里没有)。
还有一种形式的列表:
First
: First
Second Term
: Second
: Thrird
: Fourth
- First
- First
- Second
-
- Second
- Thrird
- Fourth
这个是在markdown.com.cn)上看到的,我本机并不支持,但是博客园可以(虽然会显示斜体),其嵌套规则也是看缩进。不过这个东西描述为“定义列表”,应该用来做定义,并不应该用来嵌套。
删除线、高亮线与转义表示(Strickout, Highlight and Escape)
~~这是删除~~
这是删除
==这是高亮==
这是高亮
删除线还算常见,但是高亮很多地方并不支持(但是博客园支持)。要在删除线内使用~
字符,使用转义字符\~
即可。
~~这是\~\~删除~~
这是~~删除
对于加粗或者斜体也是一样,用\*
替代*
**ds\*\*ad**
ds**ad
但是行内代码字符`
并不支持这么做,你可以自己进行尝试,即使进行转义,它往往也会优先匹配最近的两个`
,留下空空一个\
`\`and`
显示效果:\
and`。
正确的做法:如果行内代码里出现`
,就把两端的一个反引号改为两个:``
(当然要加上空格,不要连在一起)。那如果行内代码里也出现了两个`
呢?那就把两端的两个改为三个,以此类推。
`` ` ``
显示效果:`
``` `` ```
显示效果:``
(那我是怎么打出三重反引号的?那就在边上加4个了)
链接(HyperLink),图片(Picture)与Title
一般的链接是这样:[一般的链接是这样](https://www.cnblogs.com/ofnoname/p/15823373.html)
在链接后可以添加一个字符串作为Title:[在链接后可以添加一个字符串作为Title](https://www.cnblogs.com/ofnoname/p/15823373.html "Hello?Hello!")
这样,当你把鼠标移至添加了Title的链接而不点击时,鼠标旁就会显示出Title。图片也是一个道理,可以在鼠标指向图片时显示Title。
直接链接:将链接直接用<>
括起来即可,不过有些网站不能正确识别
<https://www.cnblogs.com/ofnoname/p/15823373.html>
https://www.cnblogs.com/ofnoname/p/15823373.html
引用链接:将链接放在之后的引用里,在链接处只用数字代表
[Click Me][1]
[1]: https://www.cnblogs.com/ofnoname/p/15823373.html
同时,这个链接也可以用来指向文中其他位置(定位到其他标题),最常见的就是标题标签的跳转
给图片增加链接:让图片变成可点击的,实现方法很多。其中一种是直接将两个链接暴力嵌套
脚注(Footnote)
上面的“引用链接"已经提到过一点了。真正的脚注用[^1]
类似来标记
悔相道之不察[^1]兮,延伫乎吾将反[^3]
[^1]: Footnote 1
[^3]: Footnote 2
悔相道之不察[1]兮,延伫乎吾将反[2](点击链接跳转到文尾)
可以使用任意标记关联脚注,会自动以1,2,3...排列。
待办列表(Todolist)
格式简单,无序列表加上一个框。
- [x] Write the press release
- [ ] Update the website
- [] Contact the media
框里的x表示已完成,否则未完成。一般可以手动点击更改。博客园不支持,大部分地方没有。Typora等本地编辑器有,非常美观。
添加Emoji
Emoji本质是Unicode字符,你可以直接复制表情然后粘贴在文本里(当然同一个符号在不同平台上有不同风格的,样式可能不一样,但是都是同一个表情)。不过在博客园,粘贴图片表情都会自动上传图片过后粘贴图片链接,很方便。
附魔怔笑
更通用的办法是使用:表情代码:
的形式。在emojipedia上可以查询各种的表情的显示以及短代码,常见的都可以被识别
:sweat_smile:
:joy:
不过这个仍然比较小众,很多地方没有。
自动目录(TOC)
输入[TOC]
召唤下面的目录(全文目录,标题等级动态生成的),比较常见。
流程图
很多笔记软件都支持的流程图。具体实现是在代码框中使用flowchart
或者mermaid
。这样代码区域就会自动绘制流程图。
```flow或者mermaid
//代码
```
代码里可以定义各种图形,文字以及其连接方式。除了一般的流程图,有的还可以做时序图等等。不过博客园是不支持的,并且我也很难用习惯,这里不多做介绍。给大家贴一篇别的文章,描述流程图内的语法。
一些Markdown扩展语法的更多相关文章
- Markdown扩展语法
目录 Markdown 语法补充 一.快速生成 HTML 表格代码 在线表格编辑器--TablesGenerator 二. 插入视频.音频或GIF 1. 视频 2. 音频 方法一 方法二 方法三 3. ...
- Markdown温故知新(4):更多扩展语法及HTML
1.强调(删除 & 高亮) 2.脚注(注脚) 3.数学公式 4.更多扩展语法 5.终极扩展之内嵌 HTML 5.1.文本修饰类标签 5.2.内容排版类标签 5.3.图片及多媒体标签 5.4.锚 ...
- Markdown温故知新(3):六个实用扩展语法
目录 1.表格(Table) 2.待办事项或清单(To Do List) 3.自动目录 TOC 4.流程图 5.时序图 6.甘特图 7.总结 1.表格(Table) 没用过 Markdown 表格的人 ...
- 转 - markdown 简明语法
Markdown是一种极简的『标记语言』,将文本转为HTML,通常为我大码农所用.其不追求大而全,简洁至上,正所谓不求最贵,只求最好! 本文介绍Markdown基本语法,内容很少,一行语法一行示例,学 ...
- Markdown分级语法手册
目录 前言(可以不看) 基本语法(18) 1. 标题:# 2. 无序列表:- 3. 有序列表:1. 4. 斜体:* 5. 粗体:** 6. 加粗斜体:*** 7. 删除线:~~ 8. 分隔线:--- ...
- MarkDown基础语法大全
一.MarkDown是什么? Markdown是一种轻量级的「标记语言」,创始人为约翰·格鲁伯,用简洁的语法代替排版,目前被越来越多的知识工作者.写作爱好者.程序员或研究员广泛使用.其常用的标记符号不 ...
- markdown常用语法总结
转自markdown示例[模板] 1.1.段落标题 根据原文中的文档标题可以对应设置标题. # 一级标题## 二级标题### 三级标题 效果 => 一级标题 二级标题 三级标题 1.2.斜体.加 ...
- Markdown基本语法
Markdown 基本语法记录 # 欢迎使用 Cmd Markdown 编辑阅读器 ------ 我们理解您需要更便捷更高效的工具记录思想,整理笔记.知识,并将其中承载的价值传播给他人,**Cmd M ...
- Markdown 简明语法手册
Markdown 简明语法手册 本文原文http://www.jianshu.com/p/fdb5cbdaf244 根据个人使用情况有所修改. Markdown是一种轻量级标记语言,简称md.创始人为 ...
随机推荐
- Java Record 的一些思考 - 默认方法使用以及基于预编译生成相关字节码的底层实现
快速上手 Record 类 我们先举一个简单例子,声明一个用户 Record. public record User(long id, String name, int age) {} 这样编写代码之 ...
- git 命令之暂存相关指令。
git 命令之暂存相关指令. 1.git 代码暂存指令:git stash 2.git 代码暂存列表信息:git stash list 3.git 代码应用暂存代码:git stash apply s ...
- c/c++11封装UDP,支持ipv4和ipv6,支持接收和发送
更新日志 11/06/2021 1.增加IPV6 2.ipv6通过windows10初步测试 3.ipv6包括: 接收和发送 5.增加错误代码接口 6.本机IPv6截图 7.编译通过截图 8.ipv6 ...
- 【LeetCode】26. Remove Duplicates from Sorted Array 解题报告(Python&C++&Java)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 双指针 日期 [LeetCode] https:// ...
- [LeetCode] 729. My Calendar I 731. My Calendar II 732. My Calendar III 题解
题目描述 MyCalendar主要实现一个功能就是插入指定起始结束时间的事件,对于重合的次数有要求. MyCalendar I要求任意两个事件不能有重叠的部分,如果插入这个事件会导致重合,则插入失败, ...
- vue create 初步解析以及定制化修改
版本说明 $ vue --version @vue/cli 4.5.9 $ node --version v14.0.0 $ npm --version 7.6.1 源码位置-mac /usr/loc ...
- 破解C#反编译软件Reflector 11.1.0.2167(最新版)(附补丁下载)
本文为原创作品,转载请注明出处,作者:Chris.xisaer E-mail:69920579@qq.com QQ群3244694 补丁下载地址:https://download.csdn.net/d ...
- Improving Adversarial Robustness Using Proxy Distributions
目录 概 主要内容 proxy distribution 如何利用构造的数据 Sehwag V., Mahloujifar S., Handina T., Dai S., Xiang C., Chia ...
- Chapter 8 Selection Bias
目录 8.1 The structure of selection bias 8.2 Examples of selection bias 8.3 Selection bias and confoun ...
- matplotlib 进阶之Artist tutorial(如何操作Atrist和定制)
目录 基本 plt.figure() fig.add_axes() ax.lines set_xlabel 一个完整的例子 定制你的对象 obj.set(alpha=0.5, zorder=2), o ...