Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joker/jade
Jade.go - pug template engine for Go (golang)
https://github.com/joker/jade
go golang golang-library html jade pug pug-template-engine template template-engine templates
Last synced: 1 day ago
JSON representation
Jade.go - pug template engine for Go (golang)
- Host: GitHub
- URL: https://github.com/joker/jade
- Owner: Joker
- License: bsd-3-clause
- Created: 2015-02-13T09:13:36.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2023-12-25T00:24:44.000Z (about 1 year ago)
- Last Synced: 2025-01-19T16:06:18.495Z (1 day ago)
- Topics: go, golang, golang-library, html, jade, pug, pug-template-engine, template, template-engine, templates
- Language: Go
- Homepage:
- Size: 232 KB
- Stars: 354
- Watchers: 11
- Forks: 36
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Jade.go - template engine for Go (golang)
Package jade (github.com/Joker/jade) is a simple and fast template engine implementing Jade/Pug template.
Jade precompiles templates to Go code or generates html/template.
Now Jade-lang is renamed to [Pug template engine](https://pugjs.org/language/tags.html).[![GoDoc](https://godoc.org/github.com/Joker/jade?status.svg)](https://pkg.go.dev/github.com/Joker/jade#section-documentation) [![Go Report Card](https://goreportcard.com/badge/github.com/Joker/jade)](https://goreportcard.com/report/github.com/Joker/jade)
## Jade/Pug syntax
example:```jade
//- :go:func Index(pageTitle string, youAreUsingJade bool)mixin for(golang)
#cmd Precompile jade templates to #{golang} code.doctype html
html(lang="en")
head
title= pageTitle
script(type='text/javascript').
if(question){
answer(40 + 2)
}
body
h1 Jade - template engine
+for('Go')#container.col
if youAreUsingJade
p You are amazing
else
p Get on it!
p.
Jade/Pug is a terse and simple
templating language with
a #[strong focus] on performance
and powerful features.
```becomes
```html
Jade.go
if(question){
answer(40 + 2)
}
Jade - template engine
Precompile jade templates to Go code.
You are amazing
Jade/Pug is a terse and simple
templating language with
a focus on performance
and powerful features.
```
Here are additional [examples](https://github.com/Joker/jade/tree/master/example) and [test cases](https://github.com/Joker/jade/tree/master/testdata/v2).
## Installation
Install [jade compiler](https://github.com/Joker/jade/tree/master/cmd/jade)
```console
go install github.com/Joker/jade/cmd/jade@latest
```
or github.com/Joker/jade package
```console
go get -u github.com/Joker/jade
```## Example usage
### jade compiler
```console
jade -writer -pkg=main hello.jade
```jade command[^1] precompiles _hello.jade_ to _hello.jade.go_
`hello.jade`
```
:go:func(arg) word string
doctype 5
html
body
p Hello #{word}!
````hello.jade.go`
```go
// Code generated by "jade.go"; DO NOT EDIT.
package mainimport "io"
const (
hello__0 = `Hello `
`
hello__1 = `!
)
func Jade_hello(word string, wr io.Writer) {
buffer := &WriterAsBuffer{wr}
buffer.WriteString(hello__0)
WriteEscString(word, buffer)
buffer.WriteString(hello__1)
}
````main.go`
```go
package main
//go:generate jade -pkg=main -writer hello.jadeimport "net/http"
func main() {
http.HandleFunc("/", func(wr http.ResponseWriter, req *http.Request) {
Jade_hello("jade", wr)
})
http.ListenAndServe(":8080", nil)
}
```output at localhost:8080
```htmlHello jade!
```### github.com/Joker/jade package
generate [`html/template`](https://pkg.go.dev/html/template#hdr-Introduction) at runtime
(This case is slightly slower and doesn't support[^2] all features of Jade.go)```go
package mainimport (
"fmt"
"html/template"
"net/http""github.com/Joker/hpp" // Prettify HTML
"github.com/Joker/jade"
)func handler(w http.ResponseWriter, r *http.Request) {
jadeTpl, _ := jade.Parse("jade", []byte("doctype 5\n html: body: p Hello #{.Word} !"))
goTpl, _ := template.New("html").Parse(jadeTpl)fmt.Printf("output:%s\n\n", hpp.PrPrint(jadeTpl))
goTpl.Execute(w, struct{ Word string }{"jade"})
}func main() {
http.HandleFunc("/", handler)
http.ListenAndServe(":8080", nil)
}
```console output
```html
Hello {{.Word}} !
```
output at localhost:8080
```htmlHello jade !
```## Performance
The data of chart comes from [SlinSo/goTemplateBenchmark](https://github.com/SlinSo/goTemplateBenchmark).
![chart](https://user-images.githubusercontent.com/11617/141963788-3bf16698-c41e-4dc7-9f11-80d9473009ad.png)## Custom filter :go
This filter is used as helper for command line tool
(to set imports, function name and parameters).
Filter may be placed at any nesting level.
When Jade used as library :go filter is not needed.### Nested filter :func
```
:go:func
CustomNameForTemplateFunc(any []int, input string, args map[string]int):go:func(name)
OnlyCustomNameForTemplateFunc:go:func(args)
(only string, input float32, args uint)
```### Nested filter :import
```
:go:import
"github.com/Joker/jade"
github.com/Joker/hpp
```#### note
[^1]:
`Usage: ./jade [OPTION]... [FILE]...`
```
-basedir string
base directory for templates (default "./")
-d string
directory for generated .go files (default "./")
-fmt
HTML pretty print output for generated functions
-inline
inline HTML in generated functions
-pkg string
package name for generated files (default "jade")
-stdbuf
use bytes.Buffer [default bytebufferpool.ByteBuffer]
-stdlib
use stdlib functions
-writer
use io.Writer for output
```
[^2]:
Runtime `html/template` generation doesn't support the following features:
`=>` means it generate the folowing template
```
for => "{{/* %s, %s */}}{{ range %s }}"
for if => "{{ if gt len %s 0 }}{{/* %s, %s */}}{{ range %s }}"multiline code => "{{/* %s */}}"
inheritance block => "{{/* block */}}"case statement => "{{/* switch %s */}}"
when => "{{/* case %s: */}}"
default => "{{/* default: */}}"
```
You can change this behaviour in [`config.go`](https://github.com/Joker/jade/blob/master/config.go#L24) file.
Partly this problem can be solved by [custom](https://pkg.go.dev/text/template#example-Template-Func) functions.