Go语言中text/template包用于动态生成文本,支持变量替换、条件判断、循环及自定义函数。通过Parse解析模板字符串,Execute将数据写入io.Writer。结构体字段需首字母大写以导出,.Name等占位符对应字段值。使用{{if}}进行条件控制,{{range}}遍历切片或map。可嵌套访问字段如{{.User.Name}}。通过FuncMap注册函数并用|管道调用,如{{.Name | upper}}。利用{{define}}和{{template}}实现模板复用。建议结合template.Must和错误处理确保安全。

在Go语言中,text/template 包提供了一种强大且灵活的方式来生成文本内容。无论是生成HTML页面、配置文件、邮件模板,还是自动化脚本内容,都可以通过模板引擎完成。它支持变量替换、条件判断、循环结构和自定义函数等特性,非常适合用于动态文本生成。
基本用法:定义模板与数据渲染
使用 text/template 的第一步是定义一个模板字符串或从文件加载模板,然后将数据传入并执行渲染。
示例代码:
package mainimport ( "os" "text/template" )
type User struct { Name string Email string }
func main() { const templateStr = "Hello, {{.Name}}! Your email is {{.Email}}."
t := template.Must(template.New("user").Parse(templateStr)) user := User{Name: "Alice", Email: "alice@example.com"} _ = t.Execute(os.Stdout, user)}
立即学习“go语言免费学习笔记(深入)”;
输出结果:
Hello, Alice! Your email is alice@example.com..Name 和 .Email 是模板中的占位符,对应结构体字段。注意模板通过 Execute 方法将数据写入目标 io.Writer(如 os.Stdout)。
控制结构:if、range 等逻辑处理
模板支持常见的控制结构,可用于处理复杂数据逻辑。
常用语法包括:
- {{if .Condition}}...{{end}}:条件判断
- {{if .Condition}}...{{else}}...{{end}}:带 else 分支
- {{range .Items}}...{{end}}:遍历切片或map
- {{range .Items}}{{.}} {{end}}:直接输出每个元素
示例:渲染用户列表
const tmpl = `
Users:
{{range .}}
- Name: {{.Name}}, Email: {{.Email}}
{{end}}
`
users := []User{
{Name: "Bob", Email: "bob@example.com"},
{Name: "Charlie", Email: "charlie@example.com"},
}
t := template.Must(template.New("users").Parse(tmpl))
_ = t.Execute(os.Stdout, users)
输出:
Users:Name: Bob, Email: bob@example.com
Name: Charlie, Email: charlie@example.com
嵌套结构与字段访问
模板可以访问结构体的嵌套字段,使用点号逐级访问。
例如:
type Profile struct {
User User
Age int
City string
}
const nestedTmpl = "Hi {{.User.Name}}, you are {{.Age}} years old and live in {{.City}}."
模板中通过 {{.User.Name}} 访问嵌套字段,只要字段可导出(首字母大写),就能被模板读取。
自定义函数:扩展模板能力
有时内置语法不够用,可以通过 FuncMap 注册自定义函数。
示例:添加一个转大写的函数
funcMap := template.FuncMap{
"upper": strings.ToUpper,
}
t := template.New("withFunc").Funcs(funcMap)
t, _ = t.Parse("Hello {{.Name | upper}}!")
_ = t.Execute(os.Stdout, User{Name: "dave"})
输出:Hello DAVE!
这里使用了管道符 | 将值传递给 upper 函数。自定义函数极大增强了模板的表达能力,比如格式化时间、拼接字符串、条件计算等。
模板组合:使用 define 和 template 指令
大型项目中常需要复用模板片段。可通过 define 定义命名模板,并用 template 引入。
示例:
const master = `
{{define "Greet"}}Hello, {{.Name}}{{end}}
{{template "Greet" .}}
Welcome to our system!
`
t, _ := template.New("master").Parse(master)
t.Execute(os.Stdout, User{Name: "Eve"})
这种机制适合构建布局模板、页眉页脚等可复用组件。
基本上就这些。掌握 text/template 的核心语法和使用模式后,你可以在各种场景中高效生成结构化文本。关键是理解数据如何传递到模板,以及如何用简洁的语法控制输出格式。不复杂但容易忽略细节,比如字段导出、方法签名匹配、错误处理等,建议结合 template.Must 和 proper error checks 在生产中使用。










