hugo

Fork of github.com/gohugoio/hugo with reverse pagination support

git clone git://git.shimmy1996.com/hugo.git

dict.md (2142B)

    1 ---
    2 title: dict
    3 description: Creates a dictionary from a list of key and value pairs.
    4 date: 2017-02-01
    5 publishdate: 2017-02-01
    6 lastmod: 2017-02-26
    7 categories: [functions]
    8 menu:
    9   docs:
   10     parent: "functions"
   11 keywords: [dictionary]
   12 signature: ["dict KEY VALUE [KEY VALUE]..."]
   13 workson: []
   14 hugoversion:
   15 relatedfuncs: []
   16 deprecated: false
   17 aliases: []
   18 ---
   19 
   20 `dict` is especially useful for passing more than one value to a partial template.
   21 
   22 Note that the `key` can be either a `string` or a `string slice`. The latter is useful to create a deeply nested structure, e.g.:
   23 
   24 ```go-text-template
   25 {{ $m := dict (slice "a" "b" "c") "value" }}
   26 ```
   27 
   28 
   29 ## Example: Using `dict` to pass multiple values to a `partial`
   30 
   31 The partial below creates a SVG and expects `fill`, `height` and `width` from the caller:
   32 
   33 **Partial definition**
   34 
   35 {{< code file="layouts/partials/svgs/external-links.svg" download="external-links.svg" >}}
   36 <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" 
   37 fill="{{ .fill }}" width="{{ .width }}" height="{{ .height }}" viewBox="0 0 32 32" aria-label="External Link">
   38 <path d="M25.152 16.576v5.696q0 2.144-1.504 3.648t-3.648 1.504h-14.848q-2.144 0-3.648-1.504t-1.504-3.648v-14.848q0-2.112 1.504-3.616t3.648-1.536h12.576q0.224 0 0.384 0.16t0.16 0.416v1.152q0 0.256-0.16 0.416t-0.384 0.16h-12.576q-1.184 0-2.016 0.832t-0.864 2.016v14.848q0 1.184 0.864 2.016t2.016 0.864h14.848q1.184 0 2.016-0.864t0.832-2.016v-5.696q0-0.256 0.16-0.416t0.416-0.16h1.152q0.256 0 0.416 0.16t0.16 0.416zM32 1.152v9.12q0 0.48-0.352 0.8t-0.8 0.352-0.8-0.352l-3.136-3.136-11.648 11.648q-0.16 0.192-0.416 0.192t-0.384-0.192l-2.048-2.048q-0.192-0.16-0.192-0.384t0.192-0.416l11.648-11.648-3.136-3.136q-0.352-0.352-0.352-0.8t0.352-0.8 0.8-0.352h9.12q0.48 0 0.8 0.352t0.352 0.8z"></path>
   39 </svg>
   40 {{< /code >}}
   41 
   42 **Partial call**
   43 
   44 The `fill`, `height` and `width` values can be stored in one object with `dict` and passed to the partial:
   45 
   46 {{< code file="layouts/_default/list.html" >}}
   47 {{ partial "svgs/external-links.svg" (dict "fill" "#01589B" "width" 10 "height" 20 ) }}
   48 {{< /code >}}
   49 
   50 
   51 
   52 [partials]: /templates/partials/