保姆级:Markdown 入门教程
公众号:尤而小屋
作者:Peter
编辑:Peter
一文入门 Markdown
大家好😃我叫Peter
,今天给大家带来的一篇文章是关于Markdown
的。当我正在写这篇文章的时候,我其实也是在使用Markdown
,所以这是一种很奇妙的感受:用Markdown
写关于Markdown
的文章😄。
接下来,我将从以下 6 个方面对Markdown
做一个详细的介绍,不仅帮大家快速了解Markdown
,同时也能够帮助大家快速上手Markdown
,不仅仅是入门而已。
我和 Markdown 的故事
2018 年硕士毕业后,步入社会参加了工作。因为第一份工作的原因,机缘巧合地进入了互联网这个大环境,也进入了数据这个大行业,我开始自学Python、Linux、pandas、numpy
,数据分析及可视化、数据挖掘算法,以及机器学习的入门知识。
经过两年多的不断学习和工作,我成长收获了很多,也爱上了数据这个充满前景的行业。在学习的过程中,我一直在寻找适合自己的方法和工具来记录学习的过程和成果。
一开始我在有道笔记、印象笔记等工具上进行记录,后来我转到了知乎、CSDN、掘金
等平台上。当初写作的时候,我使用的都是纯文本类似 Word 编辑的格式进行文档撰写。
但是那样真的是太丑,太low
👎了。完全没有任何的特色,还不如在 office 中直接进行编辑。因为这些平台和工具,单纯的写作是拼不过 Word 这个利器的。毕竟Word
就是专门为写作而生。
后来到了 2019 年的 2 月份,我在网上知道了 Markdown 这个语言,慢慢地去了解它,经常去使用,从此我便爱上了Markdown
。
从接触 Markdown 到现在 1 年半多的时间,我几乎每天都在使用 Markdown,可以说对它掌握到了炉火纯青的地步(吹🐂牛🍺),毕竟熟能生巧。到现在,如果不是工作上面的特殊需求,我都是Markdown
的写作,技术文档、博客、做笔记等都是用Markdown
,越用越熟,越用越爱❤️
这便是我与 Markdown 的故事
什么是 Markdown
Markdown 是一种纯文本、轻量级的文本标记语言
它不是一款软件!它不是一款软件!它不是一款软件!
通过 Markdown 的简单标记语法,我们能够以纯文本的形式编写文档,而且几乎所有的文本编辑器都能够对其进行再次编辑。
Markdown 的优势
和其他我们常见的文本编辑器,比如 office 中的 word、记事本、notepad++,还有一些开发者 IDE 的编辑工具相比,markdown 有着自己强大的优势:
标记语言
Markdown 是单纯地依靠特定的符号来标记的语言,比如-、+、*、=
通过这些标记的符号我们就能够实现特定的功能,它们能够让我们专注于写作,不用花费太多的时间和精力在排版上。
轻量级
Markdown 的轻量级体现在两个方面:
一是它的语法非常容易被记住,结构易上手,一个使用者能够很快地上手 Markdown;
二是通过 Markdown 写作的文档占据的内存大小非常低,大家看下这篇文章通过md、PDF、Word、HTML
这 4 种格式保存的效果来进行对比就知道 Markdown 到底有多么轻:
书写流畅
在利用 Markdown 进行编写的过程中,我们只需要将视线固定在光标处,在输入的时候使用不同的字符,也就是两种字符:文本字符和标记字符,我们就能同时完成文本和格式编辑。
这就是 Markdown 的神奇之处
通过上面的例子,我们可以同时完成 Markdown 的输入和格式编排👍
格式固定
同一篇 Word 的文章,在 2003、2007 或者 WPS 中很有可能打开的时候看到的效果是不一样的,甚至可能出现乱码。相信很多人碰到过这种情形。但是 md 的文章不一样:
只要能够打开 Markdown 文章的编辑器,看到效果都是相同的。
导出方便
Markdown 的格式导出是非常方便的,除了常见的 PDF、HTML 等格式,还能够直接复制到微信公众号、知乎、掘金等平台上,例如笔者的 Topyra(笔者认为最厉害的书写 Markdown 的工具)中导出的格式如此多样化:
Markdown 的使用场景
上面介绍了 Markdown 的诸多优势,那到底什么时候我们该使用它?
网络环境下的写作
首先我们要明白:Markdown 是基于 HTML 开发出来的,它的目的就是创造一个更容易读写的语言,从而用于网络上面的写作。写作即排版
所以,没有什么语言比 Markdown 更适合在网络环境写的书写
现在很多的平台都是支持 Markdown 写作的:
知乎
微信公众号
掘金
简书
CSDN
国外的一些网站,比如:Ghost、Typecho
等平台仅仅支持Markdown
格式的.md
文件
所以,Markdown 能够让我们使用专注于写作,而非排版
文档协作
一份写好的 Markdown 文档是能够在任何系统的任何文本编辑软件中打开的,能够保证在不同的系统之间进行切换,这样的好处是:
项目团队的成员能够自由地选取自己喜欢的 Markdown 工具在自己的系统上进行写作,而不受团队其他成员的系统和编辑器的限制
Markdown 文章的展示不仅仅是在我们 Markdown 编辑器中,还能够转成 HTML 网页的内容,可以让读者在浏览器中直接打开观看
特殊领域应用
由于现在 Markdown 的流行,它已经被嵌入到了很多工具中,比如笔者也是每天在使用的 jupyter notebook,一款用于机器学习和数据分析的强大利器。
在 jupyter notebook 中就能够直接使用 Markdown 进。这样使得我们在进行数据分析的同时,能够直接将我们的分析结论写在 notebook 中。
将 Markdown 编辑器和 jupyter notebook 地完美结合,极大地方便了笔者的工作,然而这时 Word 等传统的文本编辑工作无法做到的。
Markdown 工具
现在有很多的平台和工具都能够进行Markdown
的书写,Markdown
文档在它们之间也是能够相互编辑的。常见的有:
工具类的有:
Typora、Typed、Ulysses、Falcon、MacDown、Mou
,笔者使用的就是Typora
,目前它是免费的,而且有多种主题可以进行选择平台类的有:微信公众号、知乎、
CSDN
、掘金、腾讯云社区等,笔者在每个平台都有尝试过。目前在掘金和腾讯云社区比较多手机
APP
:MWeb
、马克文档等,这个笔者几乎不使用
强烈建议使用Typora
👍,这篇文章就是在 Typora 中完成的。
Markdown 语法
终于来到了介绍语法的部分,通过下面语法部分的讲解,保证能够掌握 95%的 Markdown 语法。
标题
在 Markdown 中进行编写的时候,标题也是有等级的,目前最多的是 6 级,是通过#
的个数来实现的:
实际的效果为:
引用
如果我们想在文中引用一段话,或者我们自己想将某段话当做引用的文字,可以通过下面的方式来实现:在文字的前面加一个>
符号,同时要和后面的文字隔开;
实际效果为:
路漫漫其修远兮,吾将上下而求索
当然也是分等级的,我们通过>
的个数来实现多层引用,也就是嵌套引用:
本篇文章讲解的是 Markdown,分为如下几个方面:
1.我和 Markdown 的故事
2.什么是 Markdown
3.Markdown 的优势
分割线
分割线的作用就是将上下的内容分割开来,使用的 3 个或者 3 个以上的-、+、*
(3 个符号中的一个)
比如在上面已经使用了华丽丽的分割线
字体颜色
在实际的写作过程中,我们或许想给字体加上不同的颜色进行标注,这个时候颜色标注就是最好的功能,通过一个例子来说明:
夏天是的,秋天是的
实际的源码是:
实现的方式为:$\color{指定颜色}{文本内容}$
字体高亮
有了字体的颜色设置,我们看看字体的高亮,其功能也是想突出强调某些文本,下面的内容实现了文本的高亮:
夏天是==红色==的,秋天是==黄色==的
具体的实现方式为:用一对==
将文字包裹起来即可
字体加粗
有时候我们会向对某些字体加粗处理,下面的字体实现加粗:
我是中国人,我在中国
具体的实现方式为:用一对**
将文字包裹起来
字体斜体
有时候我们想对字体实现斜体,也是想强调某些文本内容:
斜体也是起到了强调的作用
上面的斜体两字就是实现了斜体的效果,具体实现方式为:用一对*
将文本包裹
无序列表
比如笔者正在的这篇文章,分为好几个子版块,我们使用无序列表:
我和
Markdown
的故事什么是
Markdown
Markdown
的优势
实现的具体方式:在文字的前面加上-、+、*
(3 个中的一个),符号和文本之间必须要有空格(实现加粗)
有序列表
有序列表是通过数字来体现的,还是上面👆的例子,我们使用有序列表来看看效果:
我和 Markdown 的故事
什么是 Markdown
Markdown 的优势
实现的具体方式为:文字的前面加上数字和点即可,同时要有空格
注意:数字后面的点必须和之后的文字有空格
删除线
有时候在书写的过程中,我们想删除某些文字,比如经常听到的广告语:
例子:不要 199,只要 19
在上面的例子中 199 就是使用了删除线,具体的实现方式:通过一对~~
(两个波浪线)将需要删除的内容包裹起来,源码为:
下划线
下划线也是经常使用的一种字体修饰方式,我们还是通过一个例子来讲解:
例子:李白是一位<u>唐代</u>的诗人
上面例子中的唐代就是使用了下划线,具体实现的方式:通过一队<u></u>
标签将内容包裹起来,实现的源码为:
段内代码
如果我们的代码只有一行,我们使用段内代码,比如我学习的第一行代码是:print("hello world")
具体实现方式:通过一对反引号将代码包裹起来。不是单引号,不是单引号,不是单引号,具体实现的源码是:
段外代码
段外代码其实就是代码的量比较大,我们需要使用代码块的形式,比如:
使用的具体源码为:
图片
如果我们想在 Markdown 中插入图片,首先我们需要使用一个图床工具,获取到对应的 Markdown 链接,才能放到 Markdown 中。
比如:笔者在自己的 macOS 中使用的是 ipic 图床工具,将图片上床到 ipic 之后,获取到了链接:
链接
在 Markdown 中我们经常会使用链接,即当点击某写文字的时候,会自动跳转到文字指定的链接中,比如:我去年学习了python官网
在这里点击 python 官网几个字就会自动跳转到 python 的官网中去,实现的方式为:
表格
在 Markdown 中也会经常使用表格,比如一个简单的学生成绩表:
具体实现的源码为:
邮箱
使用一对<>
将你的邮箱括起来即可:123456@qq.com,具体源码为:
脚注
今天讲解了很多关于 Markdown^1的内容,希望对大家有所帮助,同时也给大家强力安利一下 Typora^2这款 Markdown 写作神器,你一定会爱上 Markdown 的
脚注会显示在文章的最后面
使用的中括号[^]
,让我们看看实现的源码(通过图片的形式看如何实现)
emoji 表情符
在Markdown
中是可以使用emoji
表情符的,使用方式是:通过一对冒号::
将对应的表情符的英文词语包裹起来,例子如下:
例子:我今天很开心:happy:
具体的源码为:
推荐一个 emoji 表情符的网站:https://emojipedia.org/
总结
本文中讲解了很多关于 Markdown 的知识,从它的特点、使用场景到常用语法,只有掌握了基本语法,经常使用它们进行文档书写,才能达到熟练生巧的底部,相信你一定会爱上 Markdown❤️。
版权声明: 本文为 InfoQ 作者【皮大大】的原创文章。
原文链接:【http://xie.infoq.cn/article/da9d284aeb53bd07a83b82ffa】。文章转载请联系作者。
评论