hugo

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

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

with.md (1427B)

    1 ---
    2 title: with
    3 # linktitle: with
    4 description: Rebinds the context (`.`) within its scope and skips the block if the variable is absent or empty.
    5 date: 2017-02-01
    6 publishdate: 2017-02-01
    7 lastmod: 2017-03-12
    8 categories: [functions]
    9 menu:
   10   docs:
   11     parent: "functions"
   12 keywords: [conditionals]
   13 signature: ["with INPUT"]
   14 workson: []
   15 hugoversion:
   16 relatedfuncs: []
   17 deprecated: false
   18 ---
   19 
   20 An alternative way of writing an `if` statement and then referencing the same value is to use `with` instead. `with` rebinds the context (`.`) within its scope and skips the block if the variable is absent, unset or empty.
   21 
   22 The set of *empty* values is defined by [the Go templates package](https://golang.org/pkg/text/template/). Empty values include `false`, the number zero, and the empty string.
   23 
   24 If you want to render a block if an index or key is present in a slice, array, channel or map, regardless of whether the value is empty, you should use [`isset`](/functions/isset) instead.
   25 
   26 The following example checks for a [user-defined site variable](/variables/site/) called `twitteruser`. If the key-value is not set, the following will render nothing:
   27 
   28 {{< code file="layouts/partials/twitter.html" >}}
   29 {{with .Site.Params.twitteruser}}<span class="twitter">
   30 <a href="https://twitter.com/{{.}}" rel="author">
   31 <img src="/images/twitter.png" width="48" height="48" title="Twitter: {{.}}"
   32  alt="Twitter"></a>
   33 </span>{{end}}
   34 {{< /code >}}