range
{{ $s := slice "foo" "bar" "baz" }}
{{ range $s }}
{{ . }} → foo bar baz
{{ end }}
Use with the else
statement:
{{ $s := slice "foo" "bar" "baz" }}
{{ range $s }}
{{ . }}
{{ else }}
The collection is empty
{{ end }}
Within a range block:
- Use the
continue
statement to stop the innermost iteration and continue to the next iteration - Use the
break
statement to stop the innermost iteration and bypass all remaining iterations
Understanding context​
At the top of a page template, the context (the dot) is a Page
object. Within the range
block, the context is bound to each successive element.
With this contrived example that uses the seq
function to generate a slice of integers:
{{ range seq 3 }}
{{ .Title }}
{{ end }}
Hugo will throw an error:
can't evaluate field Title in type int
The error occurs because we are trying to use the .Title
method on an integer instead of a Page
object. Within the range
block, if we want to render the page title, we need to get the context passed into the template.
Use the $
to get the context passed into the template.
This template will render the page title three times:
{{ range seq 3 }}
{{ $.Title }}
{{ end }}
Gaining a thorough understanding of context is critical for anyone writing template code.
Array or slice of scalars​
This template code:
{{ $s := slice "foo" "bar" "baz" }}
{{ range $s }}
{{ . }}
{{ end }}
Is rendered to:
foo
bar
baz
This template code:
{{ $s := slice "foo" "bar" "baz" }}
{{ range $v := $s }}
{{ $v }}
{{ end }}
Is rendered to:
foo
bar
baz
This template code:
{{ $s := slice "foo" "bar" "baz" }}
{{ range $k, $v := $s }}
{{ $k }}: {{ $v }}
{{ end }}
Is rendered to:
0: foo
1: bar
2: baz
Array or slice of maps​
This template code:
{{ $m := slice
(dict "name" "John" "age" 30)
(dict "name" "Will" "age" 28)
(dict "name" "Joey" "age" 24)
}}
{{ range $m }}
{{ .name }} is {{ .age }}
{{ end }}
Is rendered to:
John is 30
Will is 28
Joey is 24
Array or slice of pages​
This template code:
{{ range where site.RegularPages "Type" "articles" }}
<h2><a href="{{ .RelPermalink }}">{{ .LinkTitle }}</a></h2>
{{ end }}
Is rendered to:
<h2><a href="/articles/article-3/">Article 3</a></h2>
<h2><a href="/articles/article-2/">Article 2</a></h2>
<h2><a href="/articles/article-1/">Article 1</a></h2>
Maps​
This template code:
{{ $m := dict "name" "John" "age" 30 }}
{{ range $k, $v := $m }}
key = {{ $k }} value = {{ $v }}
{{ end }}
Is rendered to:
key = age value = 30
key = name value = John
Unlike ranging over an array or slice, Hugo sorts by key when ranging over a map.