Go语言的text/template包提供数据驱动的文本生成功能,支持变量插入{{.Field}}、条件判断{{if}}、循环遍历{{range}}及函数调用,可通过FuncMap注册自定义函数,支持模板嵌套define与template,适用于生成HTML、配置文件等内容,强调安全性与简洁性。

Go语言的
text/template包为文本处理提供了强大而灵活的工具,特别适合用于生成HTML、配置文件、代码模板或任何结构化文本内容。它通过数据驱动的方式将变量和逻辑嵌入到文本中,实现动态内容生成。
模板基础:定义与执行
使用
text/template的第一步是创建一个模板对象,并加载模板内容。模板通过双大括号
{{}}插入变量或控制结构。
示例:假设我们要生成一段用户欢迎消息:
package main
<p>import (
"os"
"text/template"
)</p><p>type User struct {
Name string
Age int
}</p><p>func main() {
const templateText = "Hello, {{.Name}}! You are {{.Age}} years old.\n"</p><pre class="brush:php;toolbar:false;">tmpl, err := template.New("greeting").Parse(templateText)
if err != nil {
panic(err)
}
user := User{Name: "Alice", Age: 25}
tmpl.Execute(os.Stdout, user)
}
输出结果为:
Hello, Alice! You are 25 years old.
立即学习“go语言免费学习笔记(深入)”;
其中
{{.Name}}和{{.Age}}表示从传入的数据结构中提取字段。
控制结构:条件与循环
模板支持基本的逻辑控制,如
if、
range等,可用于处理复杂数据结构。
例如,处理用户列表并判断年龄是否成年:
const templateText = `
{{range .}}
- Name: {{.Name}}
{{if ge .Age 18}}
Status: Adult
{{else}}
Status: Minor
{{end}}
{{end}}
`
使用
range遍历切片,
if结合比较函数(如
ge表示“大于等于”)进行条件判断。注意Go模板内置了有限的操作符,需使用
eq、
ne、
lt、
gt、
le、
ge代替常规符号。
函数与自定义方法
除了字段访问,模板还支持调用函数或方法。可以注册自定义函数到模板中。
例如,添加一个格式化函数:
funcMap := template.FuncMap{
"title": strings.Title,
}
<p>tmpl := template.New("demo").Funcs(funcMap)
然后在模板中使用:
{{title .Name}},即可将名字首字母大写。
也可以为数据类型定义方法,模板会自动识别并调用。
模板嵌套与复用
对于大型文本生成任务,可以使用
define和
template指令实现模板复用。
例如:
{{define "header"}}<h1>{{.Title}}</h1>{{end}}
<p>{{define "main"}}
{{template "header" .}}
<p>{{.Content}}</p>
{{end}}
通过
template指令引入其他命名模板,提升可维护性。
基本上就这些。Go的文本模板设计简洁,强调安全性与可预测性,不鼓励在模板中写复杂逻辑。合理使用变量、控制结构和函数扩展,就能高效完成大多数文本生成任务。










