1 回答

TA貢獻1810條經驗 獲得超5個贊
只是一個準系統解決方案如下:
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。
- 1 回答
- 0 關注
- 159 瀏覽
添加回答
舉報