内容管理概述
了解如何在 FixIt 主题中快速,直观地创建和组织内容。
1 内容组织
以下是一些方便你清晰管理和生成文章的目录结构建议:
- 保持博客文章存放在
content/posts
目录,例如:content/posts/my-first-post.md
- 保持简单的静态页面存放在
content
目录,例如:content/about.md
- 本地资源组织
有三种方法来引用图片和音乐等本地资源:
- 使用 页面包 中的 页面资源。
你可以使用适用于
Resources.GetMatch
的值或者直接使用相对于当前页面目录的文件路径来引用页面资源。 - 将本地资源放在 assets 目录中,默认路径是
/assets
。 引用资源的文件路径是相对于 assets 目录的。 - 将本地资源放在 static 目录中,默认路径是
/static
。 引用资源的文件路径是相对于 static 目录的。
引用的优先级符合以上的顺序。
在这个主题中的很多地方可以使用上面的本地资源引用,
例如 链接, 图片, image
shortcode, music
shortcode 和前置参数中的部分参数。
页面资源或者 assets 目录中的 图片处理 会在未来的版本中得到支持。 非常酷的功能!
2 前置参数
Hugo 允许你在文章内容前面添加 yaml
, toml
或者 json
格式的前置参数。
page
部分不一致时才有必要这么做。title: 文章标题
date: 这篇文章创建的日期时间它通常是从文章的前置参数中的
date
字段获取的,但是也可以在 主题配置 中设置lastmod: 上次修改内容的日期时间
draft: 如果设为
true
, 除非hugo
命令使用了--buildDrafts
/-D
参数,这篇文章不会被渲染author: 文章作者配置,和 主题配置 中的
params.author
部分相同1 2 3 4 5
author: name: "" # 文章作者 link: "" # 文章作者的链接 email: "" # 文章作者的邮箱,用于设置 Gravatar 头像,优先于 `author.avatar` avatar: "" # 文章作者的头像
description: 文章内容的描述
keywords: 文章内容的关键词
license: 这篇文章特殊的许可
images: 页面图片,用于 Open Graph 和 Twitter Cards
tags: 文章的标签
categories: 文章所属的类别
featuredImage: 文章的特色图片
featuredImagePreview: 用在主页预览的文章特色图片
hiddenFromHomePage: 如果设为
true
, 这篇文章将不会显示在主页上lightgallery: 和 主题配置 中的
params.page.lightgallery
部分相同ruby: 如果设为
true
, 这篇文章会使用 上标注释扩展语法fraction: 如果设为
true
, 这篇文章会使用 分数扩展语法fontawesome: 如果设为
true
, 这篇文章会使用 Font Awesome 扩展语法linkToMarkdown: 如果设为
true
, 内容的页脚将显示指向原始 Markdown 文件的链接pageStyle: 页面样式,详见 页面宽度
toc: 和 主题配置 中的
params.page.toc
部分相同expirationReminder: 和 主题配置 中的
params.page.expirationReminder
部分相同heading: 和 主题配置 中的
params.page.heading
部分相同code: 和 主题配置 中的
params.page.code
部分相同math: 和 主题配置 中的
params.page.math
部分相同mapbox: 和 主题配置 中的
params.page.mapbox
部分相同share: 和 主题配置 中的
params.page.share
部分相同comment: 和 主题配置 中的
params.page.comment
部分相同library: 和 主题配置 中的
params.page.library
部分相同seo: 和 主题配置 中的
params.page.seo
部分相同type: 页面渲染模板,详见 页面模板
menu: 详见 添加内容到菜单
password: 加密页面内容的密码,详见 内容加密
message: 加密提示信息,详见 内容加密
repost: 和 主题配置 中的
params.page.repost
部分相同autoBookmark: 和 主题配置 中的
params.page.autoBookmark
部分相同wordCount: 和 主题配置 中的
params.page.wordCount
部分相同readingTime: 和 主题配置 中的
params.page.readingTime
部分相同endFlag: 和 主题配置 中的
params.page.endFlag
部分相同reward: 和 主题配置 中的
params.page.reward
部分相同instantPage: 和 主题配置 中的
params.page.instantPage
部分相同
featuredImage 和 featuredImagePreview 支持 本地资源引用 的完整用法。
如果带有在前置参数中设置了 name: featured-image
或 name: featured-image-preview
属性的页面资源,
没有必要在设置 featuredImage
或 featuredImagePreview
:
|
|
FixIt 主题内嵌了一些 原型,在使用以下命令创建新内容时生效,会自动带入常用的前置参数:
|
|
这是一个前置参数例子:
|
|
3 内容摘要
FixIt 主题使用内容摘要在主页中显示大致文章信息。Hugo 支持生成文章的摘要。
3.1 自动摘要拆分
默认情况下,Hugo 自动将内容的前 70 个单词作为摘要。
你可以通过在网站配置中设置 summaryLength
来自定义摘要长度。
如果你要使用 CJK 语言创建内容,并且想使用 Hugo 的自动摘要拆分功能,请在网站配置中将 hasCJKLanguage
设置为 true
。
3.2 手动摘要拆分
另外,你也可以添加 <!--more-->
摘要分割符来拆分文章生成摘要。
摘要分隔符之前的内容将用作该文章的摘要。
<!--more-->
; 即全部为小写且没有空格。3.3 前置参数摘要
你可能希望摘要不是文章开头的文字。在这种情况下,你可以在文章前置参数的 summary
变量中设置单独的摘要。
3.4 使用文章描述作为摘要
你可能希望将文章前置参数中的 description
变量的内容作为摘要。
你仍然需要在文章开头添加 <!--more-->
摘要分割符。将摘要分隔符之前的内容保留为空。然后 FixIt 主题会将你的文章描述作为摘要。
3.5 摘要选择的优先级顺序
由于可以通过多种方式指定摘要,因此了解顺序很有用。如下:
- 如果文章中有
<!--more-->
摘要分隔符,但分隔符之前没有内容,则使用描述作为摘要。 - 如果文章中有
<!--more-->
摘要分隔符,则将按照手动摘要拆分的方法获得摘要。 - 如果文章前置参数中有摘要变量,那么将以该值作为摘要。
- 按照自动摘要拆分方法。
4 页面模板
一般情况,你不需要设置 type 参数,因为 Hugo 和 FixIt 会帮你选择。但是 FixIt 主题提供了一些特殊的模板给用户使用。
4.1 友情链接
在前置参数中设置 layout: friends
,并在 yourSite/data/
目录下创建 friends.yml
,其内容格式如下:
|
|
你可以使用以下命令快速创建友情链接页面:
|
|
5 内容加密
这部分内容在 内容加密页面 中介绍。
6 Markdown 语法
这部分内容在 Markdown 基本语法页面 和 Markdown 扩展语法页面 中介绍。
7 Shortcodes
这部分内容在 Shortcodes 页面 中介绍。