mirror of
https://github.com/gohugoio/hugo.git
synced 2024-11-14 20:37:55 -05:00
8b73644d81
0f2bf195e Adjust shortcodes for 0.55 48c577121 Fix deprecation warnings ed95a341a Update index.md e4bc8981f Release 0.55.0 25acacb91 Merge branch 'temp55' b240e321a releaser: Add release notes to /docs for release of 0.55.0 86a190c92 docs: Add information about summary front matter variable 9d94f4340 integrity: Add support for sha384 dd3fe9f92 Add HUGO_NUMWORKERMULTIPLIER 968372d86 Add trace.out to .gitignore 660772713 Add the Fireship images to cache 41a3e19cb hugolib: Allow page-relative aliases 4497e4b12 Update faq.md b0ee3dccc output: Add missing JSON tag 173dac0b7 docs: Regenerate docshelper data e30473062 docs: Regenerate CLI docs 8cb775be2 Merge commit 'c2037f0c9a3a35b9db9c404f6b5f94ec8b690a53' 5bc64bf44 Make Page an interface 371ff6c12 Add skipHTML option to blackfriday config git-subtree-dir: docs git-subtree-split: 0f2bf195ef549013cc843199fb50317b0d1a5e85
112 lines
5.3 KiB
Markdown
112 lines
5.3 KiB
Markdown
---
|
|
title: Content Summaries
|
|
linktitle: Summaries
|
|
description: Hugo generates summaries of your content.
|
|
date: 2017-01-10
|
|
publishdate: 2017-01-10
|
|
lastmod: 2017-01-10
|
|
categories: [content management]
|
|
keywords: [summaries,abstracts,read more]
|
|
menu:
|
|
docs:
|
|
parent: "content-management"
|
|
weight: 90
|
|
weight: 90 #rem
|
|
draft: false
|
|
aliases: [/content/summaries/,/content-management/content-summaries/]
|
|
toc: true
|
|
---
|
|
|
|
With the use of the `.Summary` [page variable][pagevariables], Hugo generates summaries of content to use as a short version in summary views.
|
|
|
|
## Summary Splitting Options
|
|
|
|
* Automatic Summary Split
|
|
* Manual Summary Split
|
|
* Front Matter Summary
|
|
|
|
It is natural to accompany the summary with links to the original content, and a common design pattern is to see this link in the form of a "Read More ..." button. See the `.RelPermalink`, `.Permalink`, and `.Truncated` [page variables][pagevariables].
|
|
|
|
### Automatic Summary Splitting
|
|
|
|
By default, Hugo automatically takes the first 70 words of your content as its summary and stores it into the `.Summary` page variable for use in your templates. You may customize the summary length by setting `summaryLength` in your [site configuration](/getting-started/configuration/).
|
|
|
|
{{% note %}}
|
|
You can customize how HTML tags in the summary are loaded using functions such as `plainify` and `safeHTML`.
|
|
{{% /note %}}
|
|
|
|
{{% note %}}
|
|
The Hugo-defined summaries are set to use word count calculated by splitting the text by one or more consecutive whitespace characters. If you are creating content in a `CJK` language and want to use Hugo's automatic summary splitting, set `hasCJKLanguage` to `true` in your [site configuration](/getting-started/configuration/).
|
|
{{% /note %}}
|
|
|
|
### Manual Summary Splitting
|
|
|
|
Alternatively, you may add the <code><!--more--></code> summary divider where you want to split the article.
|
|
|
|
For [Org mode content][org], use `# more` where you want to split the article.
|
|
|
|
Content that comes before the summary divider will be used as that content's summary and stored in the `.Summary` page variable with all HTML formatting intact.
|
|
|
|
{{% note "Summary Divider"%}}
|
|
The concept of a *summary divider* is not unique to Hugo. It is also called the "more tag" or "excerpt separator" in other literature.
|
|
{{% /note %}}
|
|
|
|
Pros
|
|
: Freedom, precision, and improved rendering. All HTML tags and formatting are preserved.
|
|
|
|
Cons
|
|
: Extra work for content authors, since they need to remember to type <code><!--more--></code> (or `# more` for [org content][org]) in each content file. This can be automated by adding the summary divider below the front matter of an [archetype](/content-management/archetypes/).
|
|
|
|
{{% warning "Be Precise with the Summary Divider" %}}
|
|
Be careful to enter <code><!--more--></code> exactly; i.e., all lowercase and with no whitespace.
|
|
{{% /warning %}}
|
|
|
|
### Front Matter Summary
|
|
|
|
You might want your summary to be something other than the text that starts the article. In this case you can provide a separate summary in the `summary` variable of the article front matter.
|
|
|
|
Pros
|
|
: Complete freedom of text independent of the content of the article. Markup can be used within the summary.
|
|
|
|
Cons
|
|
: Extra work for content authors as they need to write an entirely separate piece of text as the summary of the article.
|
|
|
|
## Summary Selection Order
|
|
|
|
Because there are multiple ways in which a summary can be specified it is useful to understand the order of selection Hugo follows when deciding on the text to be returned by `.Summary`. It is as follows:
|
|
|
|
1. If there is a <code><!--more--></code> summary divider present in the article the text up to the divider will be provided as per the manual summary split method
|
|
2. If there is a `summary` variable in the article front matter the value of the variable will be provided as per the front matter summary method
|
|
3. The text at the start of the article will be provided as per the automatic summary split method
|
|
|
|
{{% warning "Competing selections" %}}
|
|
Hugo uses the _first_ of the above steps that returns text. So if, for example, your article has both `summary` variable in its front matter and a <code><!--more--></code> summary divider Hugo will use the manual summary split method.
|
|
{{% /warning %}}
|
|
|
|
## Example: First 10 Articles with Summaries
|
|
|
|
You can show content summaries with the following code. You could use the following snippet, for example, in a [section template][].
|
|
|
|
{{< code file="page-list-with-summaries.html" >}}
|
|
{{ range first 10 .Pages }}
|
|
<article>
|
|
<!-- this <div> includes the title summary -->
|
|
<div>
|
|
<h2><a href="{{ .RelPermalink }}">{{ .Title }}</a></h2>
|
|
{{ .Summary }}
|
|
</div>
|
|
{{ if .Truncated }}
|
|
<!-- This <div> includes a read more link, but only if the summary is truncated... -->
|
|
<div>
|
|
<a href="{{ .RelPermalink }}">Read More…</a>
|
|
</div>
|
|
{{ end }}
|
|
</article>
|
|
{{ end }}
|
|
{{< /code >}}
|
|
|
|
Note how the `.Truncated` boolean valuable may be used to hide the "Read More..." link when the content is not truncated; i.e., when the summary contains the entire article.
|
|
|
|
[org]: /content-management/formats/
|
|
[pagevariables]: /variables/page/
|
|
[section template]: /templates/section-templates/
|