hugo搭建个人博客2-文章写作
本文是 Hugo 使用记录的第二篇,介绍关于文章写作的一些问题,包括分类管理、排版技巧、特殊语法等,所有语法基于 LoveIt 主题。
Hugo支持的文章格式为.md
,即用markdown语言编辑的文章。所有的文章都放在content/posts
目录下,支持级联目录,即在posts
目录下按分类建立多个子文件夹放置文章,比如本博客的文章按分类放在四个子文件夹下。
|
|
下面是三条方便清晰管理和生成文章的目录结构建议:
- 保持博客文章存放在
content/posts
目录, 例如:content/posts/我的第一篇文章.md
- 保持简单的静态页面存放在
content
目录, 例如:content/about.md
- 保持图片之类的媒体资源存放在
static
目录, 例如:static/images/screenshot.png
1. 前置参数
Hugo 允许在文章内容前面添加 yaml
, toml
或者 json
格式的前置参数,LoveIt 默认文章模板提供的前置参数有
|
|
- title: 文章标题.
- subtitle: 文章副标题.
- date: 这篇文章创建的日期时间. 它通常是从文章的前置参数中的
date
字段获取的, 但是也可以在 网站配置 中设置. - lastmod: 上次修改内容的日期时间.
- draft: 如果设为
true
, 除非hugo
命令使用了--buildDrafts
/-D
参数, 这篇文章不会被渲染. - author: 文章作者.
- authorLink: 文章作者的链接.
- description: 文章内容的描述.
- license: 这篇文章特殊的许可.
- tags: 文章的标签.
- categories: 文章所属的类别.
- hiddenFromHomePage: 如果设为
true
, 这篇文章将不会显示在主页上, 但是此行为可以在 网站配置 中设置的. - featuredImage: 文章的特色图片.
- featuredImagePreview: 用在主页预览的文章特色图片.
- toc: 如果设为
true
, 这篇文章会显示右侧目录. - autoCollapseToc: 如果设为
true
, 文章目录会自动折叠. - math: 如果设为
true
, 将自动渲染文章中的数学公式. - mapbox: 和 网站配置 中的
params.mapbox
对象相同. - lightgallery: 如果设为
true
, 文章中的图片将可以按照画廊形式呈现. - linkToMarkdown: 如果设为
true
, 内容的页脚将显示指向原始 Markdown 文件的链接. - share: 和 网站配置 中的
params.share
对象相同. - comment: 如果设为
true
, 将启用评论系统.
2. 标签与分类
标签和分类字段是归档文章最常用的两种形式。为了更好的使用,我们需要弄清楚它们的区别。以生活与健身的韦恩图为例1,饮食与睡眠同时属于这两个分类,当出现这类型文章时,就可以添加标签来管理。
博客文章的存储方式决定了它无法拥有太多的分类,因此,树形逐级检索的方法不适用这种情况,我们应当在将博客分为几个大类的同时,使用标签来管理和检索文章,当同样也要注意不应滥用标签,否则会带来视觉上的混乱和管理的不便。
在每篇文章的元数据(Front-Matter字段)中添加categories
字段作为文章分类,添加tags
字段作为文章标签,比如本文:
|
|
标签可以有多个,以逗号分隔,不过即使只有一个标签,外面的中括号也不能省略。
3. 排版风格规范
本节内容参考少数派写作排版指南2
3.1 空格
行文时在中文与英文、中文与数字、英文与数字之间增加空格。例如:
- 推荐:苹果公司在 2015 年 9 月 9 日发布了 iPhone 6s。
- 不推荐:苹果公司在2015年9月9日发布了iPhone 6s。
一段文字中有超链接的部分,在超链接的前后使用空格。例如:
英文前后接全角标点符号或者表示单位的角标符号时,不需要加空格。例如:
- 正确:新款屏幕的可视角度为 125°,相比旧款提升了 25%。
- 错误:新款屏幕的可视角度为 125 °,相比旧款提升了 25 %。
对于有特殊用法的专有名词,如 4K、1080p、iOS 10 等,英文和数字之间是否空格以官方标准为准。
每段文字的开头不需要空两格。
3.2 标点符号
引号使用直角引号「」,而不是弯引号 “”。对于微软拼音输入法可以键入uubd
四个字母开启标点符号的选择。
省略号使用 …… 的标准用法,正确输入方法是 shift + 6。不要使用三个句号。。。,也不要使用三个英文句点 …。
不要重复使用标点符号,尤其是在表达强烈情感的时候。例如:
- 推荐:这个提议真棒!我喜欢。
- 不推荐:这个提议真棒!!!我喜欢~~~~
同时,抒发情感的方法有很多,不建议在文中大量使用感叹号等表达强烈情感的符号,也不建议使用波浪号。
3.3 中文和西文符号
一般情况下,一个中文句子中出现了英文部分,仍然使用中文标点,即全角符号。例如:
- 正确:我常用的电子设备是 Kindle、iPad Pro、iPhone。
- 错误:我常用的电子设备是 Kindle, iPad Pro, iPhone.
如果引用一段完整的英文句子,或是出现在专有名词中的标点,则不需要更改标点符号。例如:
- 正确:乔布斯说「Stay hungry, Stay foolish.」
- 错误:乔布斯说「Stay hungry,Stay foolish。」
- 正确:我最喜欢的手机游戏是 Lifeline: Silent Night。
- 错误:我最喜欢的手机游戏是 Lifeline:Silent Night。
3.4 专有名词
所有品牌名称以官方网站写法为准,应用名称遵循 Google Play 或 App Store 的命名。若无官方中文名称,可使用网络上被大家熟知的通用译名,否则请直接使用外文名称,不要自行翻译。
请正确书写常用英文名词的大小写和空格。例如:
- 正确:iOS 10、macOS、App Store、Android
- 错误:iOS10、MacOS、AppStore、android
若应用名称过长可在文中自定缩写,但需用括号注明缩写名称,并声明「下同」。
一般情况下,品牌和应用名称不需要使用直角引号「」括起来。
在称呼 app 时,请使用「应用」「应用程序」或「app」,而非「软件」「程序」。
3.5 样式工具
虽然可以使用加粗、斜体、删除线、引用等样式工具,这些工具的使用也可以增加文章的可读性,但是过度使用则会造成排版混乱,因此建议正确、克制地使用样式工具。
例如,需要着重显示的部分请使用「加粗」功能,不要使用「斜体」,更不要使用「加粗 + 斜体」的组合。
3.6 注明引用来源
文中有使用外站或外部内容的,务必在引用最后部分注明来源。
文中有使用外站图片,必须在文末标明。来源如果来自外站必须添加链接。例如,
- 本文部分图片来自 The Verge
- 题图来自电影《春娇与志明》截图
若文章为全文翻译,必须在文中注明原作者及原文地址,并添加原文链接。
3.7 写作建议
理清文章结构,动笔之前可以先列一下写作大纲。
用主动语态,不要用被动语态。一般情况下,主动语态比被动语态更有力。
使用具体、明确、展示细节的词汇,能激发想象,使读者自己代入情境。「把硬币放进口袋里,他咧开嘴笑了」,远远强过「他满意地拿走了辛苦挣来的奖赏」。
减少形容词的使用,少用 「的」。
文中涉及到参数规格、数据的部分,要保证严谨性。
文章完成之后通读一遍,记住,不要让读者猜测你在讲什么。
4. 特殊语法
除Markdown基本语法外,灵活运用Hugo提供的一些功能,可以增加文章的灵活性。
4.1 Font Awesome
LoveIt 主题使用 Font Awesome 作为图标库. 你同样可以在文章中轻松使用这些图标.
从 Font Awesome 网站 上获取所需的图标 class
.
|
|
呈现的输出效果如下:
去露营啦! 很快就回来.
真开心!
4.2 脚注
This is a footnote3
Test all features in development4.
4.3 字符注音或注释
LoveIt 主题支持一种 字符注音或者注释 Markdown 扩展语法:
|
|
呈现的输出效果如下:
Hugo
4.4 分数
LoveIt 主题支持一种 分数 Markdown 扩展语法:
|
|
呈现的输出效果如下:
浅色/深色
90/100
4.5 数学公式
LoveIt 基于 $ \KaTeX $ 提供数学公式的支持.
在你的 网站配置 中的 [params.math]
下面设置属性 enable = true
,
并在文章的前置参数中设置属性 math: true
来启用数学公式的自动渲染.
有一份 $ \KaTeX $ 中支持的 $ \TeX $ 函数 清单.
公式块
默认的公式块分割符是 $$
/$$
和 \\[
/\\]
:
|
|
呈现的输出效果如下:
$$ c = \pm\sqrt{a^2 + b^2} $$
\[ f(x)=\int_{-\infty}^{\infty} \hat{f}(\xi) e^{2 \pi i \xi x} d \xi \]
行内公式
默认的行内公式分割符是 $
/$
和 \\(
/\\)
:
|
|
呈现的输出效果如下:
$ c = \pm\sqrt{a^2 + b^2} $ 和 \( f(x)=\int_{-\infty}^{\infty} \hat{f}(\xi) e^{2 \pi i \xi x} d \xi \)
你可以在 网站配置 中自定义公式块和行内公式的分割符.
Copy-tex
Copy-tex 是一个 $ \KaTeX $ 的插件.
通过这个扩展, 在选择并复制 $ \KaTeX $ 渲染的公式时, 会将其 $ \LaTeX $ 源代码复制到剪贴板.
在你的 网站配置 中的 [params.math]
下面设置属性 copyTex = true
来启用 Copy-tex.
选择并复制上一节中渲染的公式, 可以发现复制的内容为 LaTeX 源代码.
mhchem
mhchem 是一个 $ \KaTeX $ 的插件.
通过这个扩展, 你可以在文章中轻松编写漂亮的化学方程式.
在你的 网站配置 中的 [params.math]
下面设置属性 mhchem = true
来启用 mhchem.
|
|
呈现的输出效果如下:
$$ \ce{CO2 + C -> 2 CO} $$
$$ \ce{Hg^2+ ->[I-] HgI2 ->[I-] [Hg^{II}I4]^2-} $$
5. 扩展shortcode
关于shortcode的说明见附录I,LoveIt提供了一些shortcode的扩展语法,下面介绍可能会用到的几种。其它的(包括link、mapbox等)自行查看主题文档介绍
Bilibili
bilibili
shortcode 提供了一个内嵌的用来播放 bilibili 视频的响应式播放器,如果视频只有一个部分, 则仅需要视频的 av
ID, 例如:
|
|
一个 bilibili
示例:
|
|
如果视频包含多个部分, 则除了视频的 av
ID之外, 还需要 p
, 默认值为 1
, 例如:
|
|
一个带有 p
参数的 bilibili
示例:
|
|
Music
music
shortcode 基于 APlayer 和 MetingJS 提供了一个内嵌的响应式音乐播放器,有三种使用方式
自定义音乐 URL
music
shortcode 有以下命名参数来使用自定义音乐 URL:
server [必需]:音乐的链接.
type [可选]:音乐的名称.
artist [可选]:音乐的创作者.
cover [可选]:音乐的封面链接.
一个使用自定义音乐 URL 的 music
示例:
|
|
音乐平台 URL 的自动识别
music
shortcode 有一个命名参数来使用音乐平台 URL 的自动识别:
- auto [必需]] (第一个位置参数):用来自动识别的音乐平台 URL, 支持
netease
,tencent
和xiami
平台.
一个使用音乐平台 URL 的自动识别的 music
示例:
|
|
自定义音乐平台, 类型和 ID
music
shortcode 有以下命名参数来使用自定义音乐平台:
server [必需] (第一个位置参数):[
netease
,tencent
,kugou
,xiami
,baidu
],音乐平台.type [必需] (第二个位置参数):[
song
,playlist
,album
,search
,artist
],音乐类型.id [必需] (第三个位置参数):歌曲 ID, 或者播放列表 ID, 或者专辑 ID, 或者搜索关键词, 或者创作者 ID.
一个使用自定义音乐平台的 music
示例:
|
|
其它参数
music
shortcode 有一些可以应用于以上三种方式的其它命名参数:
theme *[可选]*音乐播放器的主题色, 默认值是
#448aff
.fixed [可选]:是否开启固定模式, 默认值是
false
.mini [可选]:是否开启迷你模式, 默认值是
false
.autoplay [可选]:是否自动播放音乐, 默认值是
false
.volume [可选]:第一次打开播放器时的默认音量, 会被保存在浏览器缓存中, 默认值是
0.7
.mutex [可选]:是否自动暂停其它播放器, 默认值是
true
.
music
shortcode 还有一些只适用于音乐列表方式的其它命名参数:
loop [可选]:[
all
,one
,none
],音乐列表的循环模式, 默认值是none
.order [可选]:[
list
,random
],音乐列表的播放顺序, 默认值是list
.list-folded [可选]:初次打开的时候音乐列表是否折叠, 默认值是
false
.list-max-height [可选]:音乐列表的最大高度, 默认值是
340px
.
Typeit
typeit
shortcode 基于 TypeIt 提供了打字动画,只需将需要打字动画的内容插入 typeit
shortcode 中即可。允许使用 Markdown
格式的简单内容, 并且 不包含 富文本的块内容, 例如图像等等…
一个 typeit
示例:
|
|
6. 写作工具
- 使用Chrome下的插件诸如
stackedit
与markdown-here
等,不用担心平台受限 - 在线如CSDN、简书、知乎、Github等都支持Markdown写作,现在越来越多的网站都已经开始支持Markdown格式的文章
- 客户端软件目前使用Typora,其它如VS code、有道云笔记、为知笔记等都支持markdown写作
附录I Shortcode
Hugo写文章的主要格式是Markdown,但是很多高级的语法默认的渲染引擎是不支持的,需要使用纯HTML代码来编写,这和Markdown的本意是违背的。因此Hugo提供了Shortcodes来提供对这些语法的支持。
短代码的调用方法为将代码放在两个大括号和一个尖括号的包围中,代码本身应与两侧尖括号有一个空格分隔。Hugo本身提供了一些Shortcodes(Build-in),但大部分都由于各种原因不能用,可用的两个分别是 Github Gist 和 Figure
figure
的文档,一个 figure
示例:
|
|
输出的 HTML 看起来像这样:
|
|
gist
的文档,一个 gist
示例:
|
|
呈现的输出效果如下:
输出的 HTML 看起来像这样:
|
|
附录II 书影音页面
因为添加书籍、电影记录过于繁琐,决定删除该页面,相关的代码放在github gist中
This is a footnote ↩︎