hugo搭建个人博客2-文章写作

警告
本文最后更新于 2020-02-17,文中内容可能已过时。

本文是 Hugo 使用记录的第二篇,介绍关于文章写作的一些问题,包括分类管理、排版技巧、特殊语法等,所有语法基于 LoveIt 主题。

Hugo支持的文章格式为.md,即用markdown语言编辑的文章。所有的文章都放在content/posts目录下,支持级联目录,即在posts目录下按分类建立多个子文件夹放置文章,比如本博客的文章按分类放在四个子文件夹下。

1
2
3
$ ls posts
爱编程爱技术的孩子/  我所热爱的生活啊/
平日里的白日梦/      研究生的区块链学习之路/

下面是三条方便清晰管理和生成文章的目录结构建议:

  • 保持博客文章存放在 content/posts 目录, 例如: content/posts/我的第一篇文章.md
  • 保持简单的静态页面存放在 content 目录, 例如: content/about.md
  • 保持图片之类的媒体资源存放在 static 目录, 例如: static/images/screenshot.png

1. 前置参数

Hugo 允许在文章内容前面添加 yaml, toml 或者 json 格式的前置参数,LoveIt 默认文章模板提供的前置参数有

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
---
title: "我的第一篇文章"
subtitle: ""
date: 2020-03-04T15:58:26+08:00
lastmod: 2020-03-04T15:58:26+08:00
draft: true
author: ""
authorLink: ""
description: ""
license: ""

tags: []
categories: []
hiddenFromHomePage: false

featured_image: ""
featured_image_preview: ""

toc: false
autoCollapsemath: true
mapbox:
    accessToken: ""
    lightStyle: ""
    darkStyle: ""
    navigation: true
    geolocate: true
    scale: true
    fullscreen: true
lightgallery: true
linkToMarkdown: true
share:
  enable: true
comment: true
---
  • 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字段作为文章标签,比如本文:

1
2
tags: [博客写作]
categories: [爱编程爱技术的孩子]

标签可以有多个,以逗号分隔,不过即使只有一个标签,外面的中括号也不能省略。

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.

1
2
3
去露营啦! :(fas fa-campground): 很快就回来.

真开心! :(far fa-grin-tears):

呈现的输出效果如下:

去露营啦!  很快就回来.

真开心!

4.2 脚注

This is a footnote3

Test all features in development4.

4.3 字符注音或注释

LoveIt 主题支持一种 字符注音或者注释 Markdown 扩展语法:

1
[Hugo]^(一个开源的静态网站生成工具)

呈现的输出效果如下:

Hugo一个开源的静态网站生成工具

4.4 分数

LoveIt 主题支持一种 分数 Markdown 扩展语法:

1
2
3
[浅色]/[深色]

[99]/[100]

呈现的输出效果如下:

浅色/深色

90/100

4.5 数学公式

LoveIt 基于 $ \KaTeX $ 提供数学公式的支持.

在你的 网站配置 中的 [params.math] 下面设置属性 enable = true, 并在文章的前置参数中设置属性 math: true来启用数学公式的自动渲染.

有一份 $ \KaTeX $ 中支持的 $ \TeX $ 函数 清单.

公式块

默认的公式块分割符是 $$/$$\\[/\\]:

1
2
3
$$ 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 \]

行内公式

默认的行内公式分割符是 $/$\\(/\\):

1
$ 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.

1
2
3
$$ \ce{CO2 + C -> 2 CO} $$

$$ \ce{Hg^2+ ->[I-] HgI2 ->[I-] [Hg^{II}I4]^2-} $$

呈现的输出效果如下:

$$ \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, 例如:

1
https://www.bilibili.com/video/av47027633

一个 bilibili 示例:

1
2
3
{{< bilibili 47027633 >}}
或者
{{< bilibili av=47027633 >}}

如果视频包含多个部分, 则除了视频的 av ID之外, 还需要 p, 默认值为 1, 例如:

1
https://www.bilibili.com/video/av36570401?p=3

一个带有 p 参数的 bilibili 示例:

1
2
3
{{< bilibili 36570401 3 >}}
或者
{{< bilibili av=36570401 p=3 >}}

Music

music shortcode 基于 APlayerMetingJS 提供了一个内嵌的响应式音乐播放器,有三种使用方式

自定义音乐 URL

music shortcode 有以下命名参数来使用自定义音乐 URL:

  • server [必需]:音乐的链接.

  • type [可选]:音乐的名称.

  • artist [可选]:音乐的创作者.

  • cover [可选]:音乐的封面链接.

一个使用自定义音乐 URL 的 music 示例:

1
{{< music url="https://rainymood.com/audio1110/0.m4a" name=rainymood artist=rainymood cover="https://rainymood.com/i/badge.jpg" >}}
音乐平台 URL 的自动识别

music shortcode 有一个命名参数来使用音乐平台 URL 的自动识别:

  • auto [必需]] (第一个位置参数):用来自动识别的音乐平台 URL, 支持 netease, tencentxiami 平台.

一个使用音乐平台 URL 的自动识别的 music 示例:

1
2
3
{{< music auto="https://music.163.com/#/playlist?id=60198" >}}
或者
{{< music "https://music.163.com/#/playlist?id=60198" >}}
自定义音乐平台, 类型和 ID

music shortcode 有以下命名参数来使用自定义音乐平台:

  • server [必需] (第一个位置参数):[netease, tencent, kugou, xiami, baidu],音乐平台.

  • type [必需] (第二个位置参数):[song, playlist, album, search, artist],音乐类型.

  • id [必需] (第三个位置参数):歌曲 ID, 或者播放列表 ID, 或者专辑 ID, 或者搜索关键词, 或者创作者 ID.

一个使用自定义音乐平台的 music 示例:

1
2
3
{{< music server="netease" type="song" id="1868553" >}}
或者
{{< music netease song 1868553 >}}
其它参数

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 示例:

1
2
3
{{< typeit >}}
这一个带有基于 [TypeIt](https://typeitjs.com/) 的 **打字动画***段落*...
{{< /typeit >}}

6. 写作工具

  • 使用Chrome下的插件诸如stackeditmarkdown-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 示例:

1
{{< figure src="/images/theme-documentation-built-in-shortcodes/lighthouse.jpg" title="Lighthouse (figure)" >}}

输出的 HTML 看起来像这样:

1
2
3
4
5
6
<figure>
    <img src="/images/theme-documentation-built-in-shortcodes/lighthouse.jpg"/>
    <figcaption>
        <h4>Lighthouse (figure)</h4>
    </figcaption>
</figure>

gist 的文档,一个 gist 示例:

1
{{< gist spf13 7896402 >}}

呈现的输出效果如下:

输出的 HTML 看起来像这样:

1
<script type="application/javascript" src="https://gist.github.com/spf13/7896402.js"></script>

附录II 书影音页面

因为添加书籍、电影记录过于繁琐,决定删除该页面,相关的代码放在github gist

支付宝
微信
0%