Blog
Post
Hugo 折腾记录:从 0 到 1
Develop ·
Hugo 安装
官方文档教程
官网针对不同系统都有详尽的安装教程介绍:https://gohugo.io/installation/
Brew
如果您是 Mac 用户,可以使用brew命令来安装。
brew install hugo注意: 这种安装方式可能安装的不是最新版本的 hugo,如果要使用最新版的 hugo,请使用其他方式安装。
配置文件格式
作为一个小白,配置文件格式是选 yaml、toml、json 就成为了我第一个疑问。
TOML
- 区分大小写
- 文件只能包含 UTF-8 编码的 Unicode 字符
- 对缩进不敏感
YAML
- 文件以’ - ‘开头,标记文档的开始
- 键值对由冒号分隔
- 列表以连字符开头
- 使用具有一个或多个空格的缩进来描述嵌套集合
JSON
- 数据存储在名称/值对中
- 记录用逗号分隔 没有以下属性的尾随逗号是不允许的
- 双引号包装属性名称和字符串
- 单引号是不允许的
字符串差异
任何格式都支持 Strings,但 JSON 不支持多行字符串,还不支持注释。
# TOMLkey = "String Value"multiline = """\ The quick brown \ fox jumps over \ the lazy dog.\ """# YAMLkey : String ValuemultilinePreservedLinebreaks:| L1 - The quick brown L2 - fox jumps over L3 - the lazy dog.multilineReplaceLinebreaksWithWhitespace:> This sentence ist just too long to keep it on the same line.// JSON{ "key": "String Value"}由于JSON较为麻烦的注释形式,YAML严格的缩进形式,我最终选择TOML作为配置文件格式,我也可以自由进行缩进,方便我查看。
零零散散的知识点
- 此符号
:=是 Python 语言中的赋值运算符(主要称为海象运算符),海象操作符压缩了我们的代码以使其更短。
var a; //定义a = 1; //赋值layout/baseof.html是所有页面的基础layout/partials文件夹中可以分部分header、footer等- 新增页面步骤:
- 需要在
content中添加一个.md文件 layouts/_default中增加同名页面- 菜单激活
active状态代码: - 根据官网说明的方式并不能成功添加
active状态,因此寻找了其他方式来判断active
{{ range .Site.Menus.main }} {{- $menu_item_url := (cond (strings.HasSuffix .URL "/") .URL (printf "%s/" .URL) ) | absLangURL }} {{- $page_url:= $currentPage.Permalink | absLangURL }} <li> <a {{- if eq $menu_item_url $page_url }} class="active" {{- end }} href="{{ .URL }}"> {{ .Pre }} <span>{{ .Name }}</span> </a> </li> {{ end }}- css 中
position功能小知识点!
.outer { position: relative;}
.inner { position: absolute; top: 0px; left: 0px;}Shortcode可以简短代码,写一些方法。类似function,具体参照写法:Hugo-basic