zoukankan      html  css  js  c++  java
  • Markdown温故知新(2):详解七大标准语法

    说明:在 Markdown 中,一行是指由换行符或回车符之外的字符构成的行,而不包含字符的行或仅包含空格或制表符的行则称之为空行。

    1、标题

    每篇文章都需要标题,不同的层级需要不同大小的标题。要在 Markdown 中实现这种分级标题的效果,只需要在标题前加上井号和空格即可,井号越多,标题越小,最多 6 个井号。具体规则如下:

    • 在文本前加 1 个#和 1 个空格,文本就会变成一级标题(对应 HTML 中的 H1)
    • 在文本前加 2 个#和 1 个空格,文本就会变成二级标题(对应 HTML 中的 H2)
    • 在文本前加 3 个#和 1 个空格,文本就会变成三级标题(对应 HTML 中的 H3)
    • 在文本前加 4 个#和 1 个空格,文本就会变成四级标题(对应 HTML 中的 H4)
    • 在文本前加 5 个#和 1 个空格,文本就会变成五级标题(对应 HTML 中的 H5)
    • 在文本前加 6 个#和 1 个空格,文本就会变成六级标题(对应 HTML 中的 H6)

    一般来说,四级标题就足够用了,所以有些 Markdown 的样式默认只对前 4 级标题做区分。

    示例一下,输入文本如下:

    # 一级标题
    ## 二级标题
    ### 三级标题
    #### 四级标题
    ##### 五级标题
    ###### 六级标题
    

    显示效果如下:

    一级标题

    二级标题

    三级标题

    四级标题

    五级标题
    六级标题

    另外,一级标题还可以在标题的下一行用等号来标识,二级标题还可以在标题的下一行用减号来标识。需要注意的是,这种语法在不同平台会有差异,有些平台只需要一个等号或减号就行,也有些平台至少需要两个,还有些平台则至少需要三个。

    换句话说,你至少需要写三个等号或减号才能确保在多数平台上都有效果。当等号或减号的数量达到三个之后,再多写就不会有额外效果了,所以有些人会疯狂的写上很多个等号或减号,其实没必要。

    示例一下,输入文本如下:

    一级标题
    ===
    二级标题
    ---
    

    显示效果如下:
    一级标题

    二级标题

    2、强调(粗体 & 斜体)

    如果不写任何标记符号,那 Markdown 编辑器对你来说就约等于记事本,可能唯一不同的地方就是无论你在 Markdown 编辑器中输入多少个空格,最终只会呈现一个。

    Markdown 默认只支持粗体和斜体,大多数时候这已经足够了。只需要在文本前后都加上星号,星号中的文本就会自动变粗或倾斜。具体规则如下:

    • 1、在文本前后各加 1 个*,文本就会变成斜体
    • 2、在文本前后各加 2 个*,文本就会变成粗体
    • 3、在文前前后各加 3 个*,文本就会变成粗斜体

    另外,也可以用下划线来代替星号,效果是一样的。

    示例一下,输入文本如下:

    科技*改变*生活,代码_改变_世界
    科技**改变**生活,代码__改变__世界
    科技***改变***生活,代码___改变___世界
    

    显示效果如下:
    科技改变生活,代码_改变_世界
    科技改变生活,代码__改变__世界
    科技改变生活,代码___改变___世界

    注意:强调效果可以嵌套到列表行和引用段落中,但不能应用到标题或代码块中。我的理解是因为标题和代码块本身就有强调的意味。

    3、列表

    Markdown 中的列表有两种,有序列表和无需列表。有序列表的每一行用一个数字、一个英文句点及一个空格来标识,无序列表的每一行用一个减号和一个空格来标识。

    有序列表,示例一下,输入文本如下:

    1. 长江
    2. 珠江
    2. 黄河
    

    显示效果如下(你有没有发现黄河前面的 2 被自动纠正为 3 了?):

    1. 长江
    2. 珠江
    3. 黄河

    无序列表,示例一下,输入文本如下:

    - 重复言说多半是时间上的损失。
    - 教育的目的在于使人能够继续教育自己。
    - 怕什么真理无穷,进一寸有一寸的欢喜。
    

    显示效果如下:

    • 重复言说多半是时间上的损失。
    • 教育的目的在于使人能够继续教育自己。
    • 怕什么真理无穷,进一寸有一寸的欢喜。

    其实,无序列表除了可以用减号来标识之外,还可以用加号或星号来标识。比如上例中的-就可以换成+*,效果完全一样,甚至可以混用这 3 种符号。

    列表嵌套,示例一下,输入文本如下:

    - 1、第一章
        - 1.1、第一节
        - 1.2、第二节
            1. 人不仅有好奇心,还有求知欲
            2. 追问事物的原理,是为了控制和利用
            3. 人发明了巫术,又从中分离出了科学
    - 2、第二章
        - 2.1、第一节
        - 2.2、第二节
    - 3、第三章
    

    显示效果如下:

    • 1、第一章
      • 1.1、第一节
      • 1.2、第二节
        1. 人不仅有好奇心,还有求知欲
        2. 追问事物的原理,是为了控制和利用
        3. 人发明了巫术,又从中分离出了科学
    • 2、第二章
      • 2.1、第一节
      • 2.2、第二节
    • 3、第三章

    引用列表,并且在列表中使用标题、粗体和斜体,示例一下,输入文本如下:

    > ## 五大联合国常任理事国
    - **中华人民共和国**
    - *美利坚合众国*
    - 俄罗斯联邦
    - 大不列颠及北爱尔兰联合王国
    - 法兰西共和国
    

    显示效果如下:

    五大联合国常任理事国

    • 中华人民共和国
    • 美利坚合众国
    • 俄罗斯联邦
    • 大不列颠及北爱尔兰联合王国
    • 法兰西共和国

    列表中还可以包含代码块,需要在代码块的前面加上 8 个空格或 2 个制表符。

    4、链接 & 图片

    文本链接的写法是用一对中括号包裹链接文本,紧接着用一对小括号包裹链接地址,即[链接文本](链接地址)。另外,还可以给链接加 title,用双引号或单引号包裹并放在链接地址后面,即[链接文本](链接地址 "title文本")

    示例一下,输入文本如下:

    [万能的淘宝](https://www.taobao.com/)
    [百度一下](https://www.baidu.com/ "你就知道")
    

    显示效果如下:
    万能的淘宝
    百度一下

    图片链接的写法只需要在文本链接的前面加上一个感叹号即可。当然链接地址得是图片地址,链接文本可写可不写,因为不会显示出来,而且不写也不影响图片的显示。

    示例一下,输入文本如下:

    ![博客园Logo](https://www.cnblogs.com/images/logo_small.gif)
    ![百度Logo](https://www.baidu.com/img/baidu_jgylogo3.gif "百度一下,你就知道")
    

    显示效果如下:
    博客园Logo
    百度Logo

    如果你在本地写作,也想看图片链接的效果,那么你需要把图片拷贝到 Markdown 文件所在的目录中,假如这个图片名称是kid.jpg,那么写法就是![](kid.jpg)。或者拷贝到所在目录的子目录中也行,加入子目录名称是imgs,那么写法就是![](imgs/kid.jpg)

    引用链接
    在实际应用中,链接地址往往是比较长的,而且有时候还需要文章中多次引用某个链接,这时候可以在 Markdown 文件末尾定义一下该链接,并设置一个简短的链接文本,然后就可以在上文中通过链接文本来引用该链接了。

    示例一下,输入文本如下:

    部分中文搜索用[百度][bd]效果更好,多数英文搜索用[谷歌][gg]效果更好,技术搜索[谷歌][gg]的效果往往要比[百度][bd]的效果好很多。
    然而遗憾的是,在中国访问[谷歌][gg]需要翻墙。
    [bd]: https://www.baidu.com/ "百度一下,你就知道"
    [gg]: https://www.google.com/ "墙外更精彩"
    

    显示效果如下:
    部分中文搜索用[百度][bd]效果更好,多数英文搜索用[谷歌][gg]效果更好,技术搜索[谷歌][gg]的效果往往要比[百度][bd]的效果好很多。
    然而遗憾的是,在中国访问[谷歌][gg]需要翻墙。
    [bd]: https://www.baidu.com/ "百度一下,你就知道"
    [gg]: https://www.google.com/ "墙外更精彩"

    上面示例的是如何引用文本链接,引用图片链接的方式与引用文本链接的方式完全相同。

    自动链接指的是当你输入一个 url 或邮箱地址等链接时,Markdown 会自动将其转换为可访问的链接,写法是将链接地址置于一对尖括号之中。

    示例一下,输入文本如下:

    <https://www.cnblogs.com/>
    https://www.cnblogs.com/ 效果对比行
    <luck@qq.com>
    luck@qq.com 效果对比行
    

    显示效果如下:
    https://www.cnblogs.com/
    https://www.cnblogs.com/ 效果对比行
    luck@qq.com
    luck@qq.com 效果对比行

    可能你会发现,在你使用的编辑器中写不写尖括号效果都一样,那是因为你使用的编辑器自带了链接识别功能。在很多博客或网络笔记中,要想链接显示成链接的效果,还是得加尖括号。

    5、代码块

    在 Markdown 的所有语法中,代码快大概是最能打动程序员的。尽管在程序员之外的人看来,代码快的效果不过是给文本加了个框,但写过文档的程序员都知道 Word 等文字处理软件中代码的显示效果和编辑效果有多糟糕。

    代码块有两种:一种是行内代码块,用两个反单引号(也称重音符)包裹一下即可;另一种是多行代码快,在每行代码前加四个空格或一个制表符(Tab)的缩进,然后与上一行文本之间保留一个空行即可。

    行内代码块,示例一下,输入文本如下:

    JavaScript 在控制台输出消息的语法是 `console.log(message)`。
    

    显示效果如下:
    JavaScript 在控制台输出消息的语法是 console.log(message)

    多行代码快,示例一下,输入文本如下:

        class Program {
            static void Main(string[] args) {
                Console.WriteLine("Hello World!");
            }
        }
    

    显示效果如下:

    class Program {
        static void Main(string[] args) {
            Console.WriteLine("Hello World!");
        }
    }
    

    有些工具或平台支持很多语言的代码高亮,现实效果非常好。常见标准中都没有规定这一块,所以如果你想要代码高亮,就得按你所用工具的语法规则来写了。

    关于多行代码快,CommonMark 标准中定义了一个相对来说更加方便书写的语法,就是以三个独占一行的反单引号开头,并且以三个独占一行反单引号结尾。这样就不用写缩进了,而且代码块与上一行之间也不必再保留一个空行了。而且常见的各种工具基本都支持,似乎已经成为事实上的标准了。

    示例一下,输入文本如下:
    class Program { static void Main(string[] args) { Console.WriteLine("Hello World!"); } }
    显示效果如下:

    class Program {
        static void Main(string[] args) {
            Console.WriteLine("Hello World!");
        }
    }
    

    6、引用

    如果需要在文中引入一段有出处的话,就可以采用引用的方式实现。实现的方式是在这段话的开头或上一行加上一个尖括号和一个空格。虽然 Markdown 的引用语法很简洁,但用法却很灵活,几乎可以和任何语法连用,而且很强大,能够逐级嵌套引用。

    普通引用,示例一下,输入文本如下:

    > 普通文本 **加粗文本** *斜体文本*
    > ## 二级标题
    > #### 四级标题
    

    显示效果如下:

    普通文本 加粗文本 斜体文本

    二级标题

    四级标题

    嵌套引用,示例一下,输入文本如下:

    > 一层引用
    >> 两层引用
    >>> 三层引用
    >>>> 四层引用
    >>>>> 五层引用
    

    显示效果如下:

    一层引用

    两层引用

    三层引用

    四层引用

    五层引用

    7、分割线

    有些作者很喜欢用水平分割线,也称分隔符或横线,在 Markdown 中,分割线的写法与标题的第二种写法十分相似,在新的一行连续输入 3 个或 3 个以上的星号即可。

    星号之间可以有空格,且星号还可以用减号或下划线来代替。需要注意的是,如果用减号,那分割线与上面的段落之间需要空出一行,否则分割线就会与上面的段落组成二级标题了。

    示例一下,输入文本如下:

    ***
    * * *
    
    ---(注意:此行的上一行是空着的)
    ___
    

    显示效果如下:





    8、总结

    本文主要讲解了 Markdown 的七大标准语法的用法。掌握了这七大标准语法,就足够应对 Markdown 的一般写作需求了。

    通过本文示例可见,Markdown 的语法完全由标点符号构成,且标点符号经过精心挑选,看起来比较直观形象。例如,文本周围的*看起来像是在强调,分割线看起来就像是横线,列表排列看起来就像是列表。

    本文链接http://www.cnblogs.com/hanzongze/p/markdown-standards.html
    版权声明:本文为博客园博主 韩宗泽 原创,作者保留署名权!欢迎通过转载、演绎或其它传播方式来使用本文,但必须在明显位置给出作者署名和本文链接!个人博客,能力有限,若有不当之处,敬请批评指正,谢谢!

  • 相关阅读:
    创业公司技术总监,去上市公司面试,结果凉了!
    Java开发最常犯的10个错误,打死都不要犯!
    这 17 个 JVM 参数,高级 Java 必须掌握!
    推荐几个顶级的IT技术公众号,坐稳了!
    Spring Boot 面试,一个问题就干趴下了!(下)
    密码已进入"淘汰"倒计时!
    一条简单的 SQL 执行超过1000ms,纳尼?
    天天用Synchronized,底层原理是个啥?
    为什么很多程序员工作时都戴耳机?
    Java转型大数据开发全套教程,都在这儿!
  • 原文地址:https://www.cnblogs.com/hanzongze/p/markdown-standards.html
Copyright © 2011-2022 走看看