只是一个准系统解决方案如下:
package main
import (
"fmt"
"os"
"text/template"
)
func main() {
//read in one go the header, footer and all your other tmpls.
//append to that slice every time the relevant content that you want rendered.
alltmpls := []string{"./layouts/header.tmpl", "./layouts/footer.tmpl", "./users/index.tmpl"}
templates, err := template.ParseFiles(alltmpls...)
t := templates.Lookup("header.tmpl")
t.ExecuteTemplate(os.Stdout, "header", nil)
t = templates.Lookup("index.tmpl")
t.ExecuteTemplate(os.Stdout, "index", nil)
t = templates.Lookup("footer.tmpl")
t.ExecuteTemplate(os.Stdout, "footer", nil)
}
实际上,您可能需要一个返回适当文件切片的函数来填充 alltmpls 变量。它应该扫描您的目录并从那里获取所有文件以传递给 ParseFiles() 然后继续为每个模板调用 Lookup 和 ExecuteTemplate 步骤。
进一步考虑这个想法,我将创建一个新类型,该类型将嵌入一个模板(或模板片段),由页眉和页脚进行注释。
type hftemplate struct {
template.Template
header, footer *template.Template
}
func (h *hftemplate) ExecuteTemplate(wr io.Writer, name string, data interface{}) error {
h.header.ExecuteTemplate(wr, "header", nil)
err := h.ExecuteTemplate(wr, name, data)
h.footer.ExecuteTemplate(wr, "footer", nil)
return err
}
当然,您可以将该结构嵌入转换为 []Template 的完整字段,以在页眉和页脚之间执行多个 ExecuteTemplates。