Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hoisie/mustache
The mustache template language in Go
https://github.com/hoisie/mustache
Last synced: 2 days ago
JSON representation
The mustache template language in Go
- Host: GitHub
- URL: https://github.com/hoisie/mustache
- Owner: hoisie
- License: mit
- Created: 2009-12-30T21:05:05.000Z (about 15 years ago)
- Default Branch: master
- Last Pushed: 2024-04-28T16:34:44.000Z (9 months ago)
- Last Synced: 2024-10-29T15:27:15.945Z (2 months ago)
- Language: Go
- Homepage:
- Size: 308 KB
- Stars: 1,108
- Watchers: 35
- Forks: 225
- Open Issues: 33
-
Metadata Files:
- Readme: Readme.md
- License: LICENSE
Awesome Lists containing this project
- go-awesome - Moustache
- awesome-cobol - mustache - A Cobol implementation of the Mustache template language. (Template Engines / Middlewares)
- awesome-go - mustache - The mustache template language in Go - ★ 945 (Template Engines)
README
## Overview
mustache.go is an implementation of the mustache template language in Go. It is better suited for website templates than Go's native pkg/template. mustache.go is fast -- it parses templates efficiently and stores them in a tree-like structure which allows for fast execution.
## Documentation
For more information about mustache, check out the [mustache project page](http://github.com/defunkt/mustache) or the [mustache manual](http://mustache.github.com/mustache.5.html).
Also check out some [example mustache files](http://github.com/defunkt/mustache/tree/master/examples/)
## Installation
To install mustache.go, simply run `go get github.com/hoisie/mustache`. To use it in a program, use `import "github.com/hoisie/mustache"`## Usage
There are four main methods in this package:```go
func Render(data string, context ...interface{}) stringfunc RenderFile(filename string, context ...interface{}) string
func ParseString(data string) (*Template, os.Error)
func ParseFile(filename string) (*Template, os.Error)
```There are also two additional methods for using layouts (explained below).
The Render method takes a string and a data source, which is generally a map or struct, and returns the output string. If the template file contains an error, the return value is a description of the error. There's a similar method, RenderFile, which takes a filename as an argument and uses that for the template contents.
```go
data := mustache.Render("hello {{c}}", map[string]string{"c":"world"})
println(data)
```If you're planning to render the same template multiple times, you do it efficiently by compiling the template first:
```go
tmpl,_ := mustache.ParseString("hello {{c}}")
var buf bytes.Buffer;
for i := 0; i < 10; i++ {
tmpl.Render (map[string]string { "c":"world"}, &buf)
}
```For more example usage, please see `mustache_test.go`
## Escaping
mustache.go follows the official mustache HTML escaping rules. That is, if you enclose a variable with two curly brackets, `{{var}}`, the contents are HTML-escaped. For instance, strings like `5 > 2` are converted to `5 > 2`. To use raw characters, use three curly brackets `{{{var}}}`.
## Layouts
It is a common pattern to include a template file as a "wrapper" for other templates. The wrapper may include a header and a footer, for instance. Mustache.go supports this pattern with the following two methods:
```go
func RenderInLayout(data string, layout string, context ...interface{}) stringfunc RenderFileInLayout(filename string, layoutFile string, context ...interface{}) string
```
The layout file must have a variable called `{{content}}`. For example, given the following files:layout.html.mustache:
```html
Hi
{{{content}}}
```
template.html.mustache:
```html
Hello World!
```A call to `RenderFileInLayout("template.html.mustache", "layout.html.mustache", nil)` will produce:
```html
Hi
Hello World!
```
## A note about method receivers
Mustache.go supports calling methods on objects, but you have to be aware of Go's limitations. For example, lets's say you have the following type:
```go
type Person struct {
FirstName string
LastName string
}func (p *Person) Name1() string {
return p.FirstName + " " + p.LastName
}func (p Person) Name2() string {
return p.FirstName + " " + p.LastName
}
```While they appear to be identical methods, `Name1` has a pointer receiver, and `Name2` has a value receiver. Objects of type `Person`(non-pointer) can only access `Name2`, while objects of type `*Person`(person) can access both. This is by design in the Go language.
So if you write the following:
```go
mustache.Render("{{Name1}}", Person{"John", "Smith"})
```It'll be blank. You either have to use `&Person{"John", "Smith"}`, or call `Name2`
## Supported features
* Variables
* Comments
* Change delimiter
* Sections (boolean, enumerable, and inverted)
* Partials