mirror of
				https://github.com/gohugoio/hugo.git
				synced 2024-05-11 05:54:58 +00:00 
			
		
		
		
	
		
			
	
	
		
			113 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			113 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 variable value 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/ |