Jekyll 代码块展示
Jekyll 代码块展示
展示代码高亮是每个技术博客与生俱来的使命,而展示行号,也是一个不可或缺的需求。对 Jekyll 用户的好消息是,官方对此提供了友好的支持。
语法高亮
常规的 Markdown 语法:使用 ```
或者 ~~~
符号可以展示语法高亮代码块。另外,也可以使用 Jekyll 的 highlight
tag,例如,展示一段 HTML 代码:
1
2
3
{% highlight html %}
<p>This is some text in a paragraph.</p>
{% endhighlight %}
显示行号
有两种方式可以选择:
使用 Kramdown 配置
按这种方法可以对常规的 Markdown 的代码段自动显示行号,故为首选。启用时,在 _config.yml
中添加以下配置:
1
2
3
4
5
6
7
8
9
kramdown:
syntax_highlighter: rouge
syntax_highlighter_opts: # Rouge Options › https\://github.com/jneen/rouge#full-options
css_class: highlight
span:
line_numbers: false
block:
line_numbers: true
start_line: 1
使用 highlight
在 highlight
后面声明类 linenos
也可以显示行号:
1
2
3
{% highlight html linenos %}
<p>This is some text in a paragraph.</p>
{% endhighlight %}
特殊代码处理
Markdown 解析代码块时,如遇到 Liquid 的源码,由于转义字符 {
及 }
,会使用得 Liquid 的部分不被渲染。举个例子,假设源代码是:
1
2
3
4
5
<p>
{% if site.data.showAuthor %}
Author: {{ site.data.author }}
{% endif %}
</p>
那么 Jekyll 编译后的 HTML 输出结果是:
1
<p></p>
可见 Liquid 部分 {% if %}...{% endif %}
已经丢失了。为此,Jekyll 提供了两种解决方法:
用标签
{% raw %}
与{% endraw %}
包裹转义字符:1 2 3 4 5 6 7
{% raw %} <p> {% if site.data.showAuthor %} Author: {{ site.data.author }} {% endif %} </p> {% endraw %}
作为替代,如果 Jekyll 的版本在 4.0 及以上,也可以在 post 顶部的 YAML 区域指定:
1 2 3
--- render_with_liquid: false ---
两种方法的输出都是:
1
<p>Author: Bob</p>
使用场景的考虑
无论是需要显示语法高亮还是行号,都推荐以配置 kramdown 选项的方式去实现,毕竟效率第一。当然了,如果你是重度编码癖坚持要敲完一大串词组 {% raw %}{% highlight %}...{% endhighlight %}{% endraw %}
,那么请随意享受宪法赋予你的自由。
参考
This post is licensed under CC BY 4.0 by the author.