Templates in Golang

In this post, we will see templates and their usages in the Go programming language.

What are templates?

Templates are a common view through which we can pass data to make that view meaningful. It can be customized in any way to get any output possible.

Template packages

Templating in Go comes with two packages text/template and html/template . The text package allows us to interpolate texts with the template, while HTML templating helps us by providing the safe HTML code.

Parts of a template

Let’s have a look at different parts of the code before we start using them.

1. Template actions

Template actions are the main control flows, data evaluations, functions. These actions control how the final output will show up. Here are some basic actions as shown below.

{{ /* a comment inside template */ }}

To render the root element:

{{ . }}

2. Control structures

Control structures determine the control flow of the template. It helps to produce structured output. Below are some control structures in templating.

The if statement:

{{ if .condition }} {{ else }} {{ end }}

The range block:

{{ range .Items }} {{ end }}

Range block iterates over the list provided.

3. Functions

Functions can be used inside templates as well. We can use the pipe ( | ) operator to use predefined functions.

Parsing templates in Go

Now we will parse some text and HTML templates.

1. Accessing data

To access the data passed we use the dot (.) syntax like shown below.

{{ .data }}

2. Parsing a text template

Now we will parse a text template as shown below.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
package main
 
import (
    "os"
    "text/template"
)
 
type User struct {
    Name    string
    Bio     string
}
 
func main() {
    u := User{"John", "a regular user"}
 
    ut, err := template.New("users").Parse("The user is {{ .Name }} and he is {{ .Bio }}.")
     
    if err != nil {
        panic(err)
    }
 
    err = ut.Execute(os.Stdout, u)
 
    if err != nil {
        panic(err)
    }
}

In the code above a struct is passed in a text template the output is shown below.

String Template Parse
String Template Parse

3. Parsing an HTML template

Let’s try parsing an HTML document. Below show codes are used for this example.

In file hello.gohtml :

1
2
3
4
5
6
<h1>Go templates</h1>
<p>The user is {{ .Name }}</p>
<h2>Skills:</h2>
{{ range .Skills }}
    <p>{{ . }}</p>
{{ end }}

In file main.go:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
package main
 
import (
    "os"
    "html/template"
)
 
func main() {
    t, err := template.ParseFiles("templates/hello.gohtml")
 
    if err != nil {
        panic(err)
    }
 
    data := struct {
        Name string
        Skills []string
    }{
        Name: "John Doe",
        Skills: []string{
            "C++",
            "Java",
            "Python",
        },
    }
 
    err = t.Execute(os.Stdout, data)
 
    if err != nil {
        panic(err)
    }
}
Html Template Parsing 1
Html Template Parsing

Template Verification in Go

To verify if a template is valid, we use template.Must() function. It helps verify the template during parsing.

1
tmp := template.Must(template.ParseFiles("tmp.html"))

We use it like shown before.

Usage of Templating in Go Programming

Templating can be extremely useful in many conditions not just in general web page creation only. But,

  1. Generate a web page using data from API.
  2. Generate emails
  3. Create web sites using HUGO templating.