Features of the Template Engine
- Simple, easy to use, powerful;
- Supports multiple template directory searches;
- Supports
layout
template design; - Supports singleton mode for template view objects;
- Natively integrated with the configuration management module, easy to use;
- Utilizes a two-level cache design at the core, offering high performance;
- Adds new template tags and numerous built-in template variables and functions;
- Supports automatic cache update mechanism upon template file modification, which is more developer-friendly;
define
/template
tags support cross-template invocation (including template files under the same template path with subdirectories);include
tag supports importing template files from any path;
General View Management
General view management involves using the native template engine gview
module to implement template management, including template reading and display, template variable rendering, etc. You can use the method gview.Instance
to obtain a view singleton object and retrieve it according to the singleton object name. You can also obtain the default singleton gview
object through the object manager g.View()
.
Interface Documentation:
https://pkg.go.dev/github.com/gogf/gf/v2/os/gview
Brief Explanation:
gview.Get
is used to obtain the corresponding singleton template engine object based on a given template directory path;gview.New
can also create a template engine object based on the given template directory path but without singleton management;SetPath/AddPath
is used to set/add the template directory path of the current template engine object, whereSetPath
will overwrite all template directory settings, andAddPath
is recommended;Assign/Assigns
is used to set template variables, and all templates parsed by the template engine can use these template variables;BindFunc
is used to bind template functions; for detailed usage, refer to subsequent examples;Parse/ParseContent
is used to parse template files/content, allowing for temporary template variables and template functions to be given during parsing;SetDelimiters
is used to set the template parsing delimiters of the template engine object, defaulting to{{ }}
(conflicts with thevuejs
front-end framework);
Note: Starting with goframe v1.16
, all template parsing methods have an additional first input parameter which is the Context
.
Example 1: Parsing a Template File
index.tpl
id:{{.id}}, name:{{.name}}
main.go
package main
import (
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/net/ghttp"
)
func main() {
s := g.Server()
s.BindHandler("/template", func(r *ghttp.Request) {
r.Response.WriteTpl("index.tpl", g.Map{
"id": 123,
"name": "john",
})
})
s.SetPort(8199)
s.Run()
}
After execution, visiting http://127.0.0.1:8199/template will show the parsed content as: id:123, name:john
Example 2: Parsing Template Content
package main
import (
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/net/ghttp"
)
func main() {
s := g.Server()
s.BindHandler("/template", func(r *ghttp.Request){
tplContent := `id:{{.id}}, name:{{.name}}`
r.Response.WriteTplContent(tplContent, g.Map{
"id" : 123,
"name" : "john",
})
})
s.SetPort(8199)
s.Run()
}
After execution, visiting http://127.0.0.1:8199/template will show the parsed content as: id:123, name:john
Example 3: Custom Template Delimiters
In projects, we often encounter a conflict between Golang
default template variable delimiters and Vue
variable delimiters (both use {{ }}
). We can use the SetDelimiters
method to customize the global Golang
template variable delimiters:
// main.go
package main
import (
"context"
"fmt"
"github.com/gogf/gf/v2/frame/g"
)
func main() {
v := g.View()
v.SetDelimiters("${", "}")
b, err := v.Parse(
context.TODO(),
"gview_delimiters.tpl",
map[string]interface{}{
"k": "v",
})
fmt.Println(err)
fmt.Println(b)
}
<!-- gview_delimiters.tpl -->
test.tpl content, vars: ${.}
After execution, the resulting output is:
<nil>
test.tpl content, vars: map[k:v]
Directory Configuration Method
The GoFrame
framework's template engine supports a highly flexible multi-directory auto-search function. The SetPath
can modify the template directory to a single directory address. Additionally, the AddPath
method can add multiple search directories, and the template engine will prioritize the added directories according to the order they were added, performing automatic retrieval. It searches until it finds a matching file path. If no template file is found in all search directories, it returns failure.
Default Directory Configuration:
When initializing the gview
view object, the following template file search directories are automatically added by default:
- The current working directory and its
template
subdirectory: For example, if the current working directory is/home/www
,/home/www
and/home/www/template
will be added; - The directory where the current executable is located and its
template
subdirectory: For example, if the binary file is located in/tmp
,/tmp
and/tmp/template
will be added; - The directory where the
main
source code package is located and itstemplate
subdirectory (effective only in the source code development environment): For example, if themain
package is located in/home/john/workspace/gf-app
,/home/john/workspace/gf-app
and/home/john/workspace/gf-app/template
will be added;
Modifying the Template Directory
The view object's template file search directory can be modified in the following ways. The view object will only perform configuration file retrieval in the specified directory:
- (Recommended) Retrieve the global View object in singleton mode and modify it via the
SetPath
method; - Modify command line start parameters -
gf.gview.path
; - Modify specified environment variables -
GF_GVIEW_PATH
;
For example, if our executable file is main
, the template engine's template directory can be modified in the following ways on Linux:
- (Recommended) Through singleton mode
g.View().SetPath("/opt/template")
- Via command line parameters
./main --gf.gview.path=/opt/template/
- Via environment variables
-
Modify the environment variable at startup:
GF_GVIEW_PATH=/opt/config/; ./main
-
Use the
genv
module to modify the environment variable:genv.Set("GF_GVIEW_PATH", "/opt/template")
-
Automatic Update Detection
The template engine uses a carefully designed cache mechanism. When a template file is first read, it is cached in memory, and future reads will directly access the cache to improve execution efficiency. Additionally, the template engine provides an automatic update detection mechanism for template files. When a template file is modified externally, the template engine can promptly detect it and refresh the cache content of the template file.
Documentation
📄️ Template Engine - Configuration
The view component of the GoFrame framework is one of its cores, supporting convenient configuration management. This article provides a detailed introduction on managing view components through configuration files, including the definitions and examples of configuration items. It also explains how to use the SetConfigWithMap method for specific configuration settings to ensure proper template parsing.
📄️ Template Engine - Tags
The basic usage of template engines and template tags in the GoFrame framework, including how to customize template delimiters, use pipelines to pass data in templates, usage of conditional statements if...else, range to iterate types like slice, map, using define to define template blocks, template tag combined with define for template nesting and reuse, and the difference in usage of the include tag in the GoFrame framework.
📄️ Template Engine - Variables
How to use custom objects as template variables in the template engine, and access object properties and call methods within the template. This is explained in detail through examples, illustrating how to implement template content parsing in the GoFrame framework, as well as the differences between using object pointers and object variables, and the rules for method calls, helping developers better master the templating technology in the GoFrame framework.
📄️ Template Engine - Layout
The layout template layout method of the gview template engine in the GoFrame framework. gview supports two layout methods: content block management through define and template tags, and template embedding through include tags. Both methods support the transfer of template variables. The sample code demonstrates how to use these template engine techniques in the GoFrame framework.
📄️ Template Engine - XSS
XSS handling when using the GoFrame framework's template engine. By default, output variables are not HTML encoded, which may lead to XSS vulnerabilities. However, the GoFrame framework provides flexible configuration options to control encoding effects through the AutoEncode or SetAutoEncode methods to enhance output security.
📄️ Template Engine - Others
Using different features of the template engine in the GoFrame framework, including support for I18N features and implementation in Http objects and controllers. Through example code, we demonstrate template parsing syntax and data isolation management in multi-threaded environments. Also includes usage notes on non-recommended controller registration methods.
🗃️ Template Engine - Funcs
3 items