当我尝试使用Funcs
和FuncMap
时,它注意到Go模板很奇怪。以下代码按预期工作:
buffer := bytes.NewBufferString("")
funcMap := template.FuncMap{
"label": strings.Title,
}
t, _ := template.New("alex").Funcs(funcMap).Parse("{{label \"alex\"}}")
t.Execute(buffer, "")
return string(buffer.Bytes()) //=> "Alex"
但是当我尝试将模板放入文件时,它不起作用(Execute()
说:"alex" is an incomplete or empty template
):
t, _ := template.New("alex").Funcs(funcMap).ParseFiles("template.html")
使用template.html:
{{label \"alex\"}}
知道为什么吗?这是一个错误吗?是否有更简单的方法在模板中使用方法/功能?
答案 0 :(得分:32)
ParseFiles可能会使用更好的文档。模板对象中可以包含多个模板,每个模板都有一个名称。如果查看ParseFiles的实现,您会看到它使用 filename 作为模板对象内的模板名称。因此,将文件命名为与模板对象相同(可能通常不实用),或者使用ExecuteTemplate而不是Execute。
答案 1 :(得分:16)
索尼娅的回答在技术上是正确的,但让我更加困惑。以下是我最终如何运作:
t, err := template.New("_base.html").Funcs(funcs).ParseFiles("../view/_base.html", "../view/home.html")
if err != nil {
fmt.Fprint(w, "Error:", err)
fmt.Println("Error:", err)
return
}
err = t.Execute(w, data)
if err != nil {
fmt.Fprint(w, "Error:", err)
fmt.Println("Error:", err)
}
模板的名称是模板的裸文件名,而不是完整路径。 Execute
将执行默认模板,前提是它的名称匹配,因此无需使用ExecuteTemplate
。
在这种情况下,_base.html
文件是最外面的容器,例如:
<!DOCTYPE html>
<html><body>
<h1>{{ template "title" }}</h1>
{{ template "content" }}
</body></html>
而home.html
定义了特定部分:
{{ define "title" }}Home{{ end }}
{{ define "content" }}
Stuff
{{ end }}
答案 2 :(得分:0)
您需要首先解析所有文件并执行它们。您不能直接访问所有文件。