模板不渲染任何内容,也没有错误,但状态为 200

我正在一个简单的 HTTP 服务器中使用 Go:


// var tpl = template.Must(template.New("").Funcs(template.FuncMap{"isRegistered": isRegistered}).ParseGlob("templates/*")) // functions will be added later

var tpl = template.Must(template.ParseGlob("templates/*"))


func contact(w http.ResponseWriter, r *http.Request) {

    //// defined templates are: "home.html", "layout", "layout.html", "contact.html", "body"

    log.Println("in handler: ", tpl.DefinedTemplates())


    err := tpl.ExecuteTemplate(w, "contact.html", nil)

    if err != nil {

        fmt.Println(err) // no error displayed

    }

    // fmt.Fprintf((w), "write") - This works fine

}


func main() {


    log.Println("Serving on 8888 port")

    http.HandleFunc("/contact", contact)


    http.ListenAndServe(":8888", nil)

}



{{define "layout"}}

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title>{{.Title}}</title>

    <meta name="description" content="{{.Description}}">

    <link rel="canonical" href="{{.Canonical}}" />

</head>

<body>


{{template "body" .}}


</body>

</html>

{{end}}

{{define "body"}}

<h1>Contact us page</h1>


<p>

    Your name is...

</p>


{{end}}


localhost :8888/contact返回 OK 200 和空正文。我使用了这个例子:https ://stackoverflow.com/a/36643663/2110953


但我将来还需要添加模板函数: var tpl = template.Must(template.New("").Funcs(template.FuncMap{"isRegistered": isRegistered}).ParseGlob("templates/*"))


米琪卡哇伊
浏览 84回答 2
2回答

眼眸繁星

你的contact.html不“渲染”任何东西。它仅定义body模板,但不包含它(执行它)。要执行模板(模板内),您可以使用该{{template}}操作。要定义和执行模板,您可以使用该{{block}}操作。模板操作:{{template "name"}}    The template with the specified name is executed with nil data.{{template "name" pipeline}}    The template with the specified name is executed with dot set    to the value of the pipeline.{{block "name" pipeline}} T1 {{end}}    A block is shorthand for defining a template        {{define "name"}} T1 {{end}}    and then executing it in place        {{template "name" pipeline}}    The typical use is to define a set of root templates that are    then customized by redefining the block templates within.如果您的目标是在所有页面中拥有“固定”页眉和页脚,那么您必须重新构建模板。在某处定义了header和footer模板,并且页面应将它们作为第一个和最后一个元素包含在内。

千巷猫影

更新:所以我不得不创建一个页眉和页脚模板:{{template "header" .}}<h1>Contact us page</h1><p>&nbsp; &nbsp; Your name is...</p>{{template "footer" .}}{{define "header"}}<!DOCTYPE html><html><head>&nbsp; &nbsp; <meta charset="UTF-8">&nbsp; &nbsp; <title>{{.Title}}</title>&nbsp; &nbsp; <meta name="description" content="{{.Description}}">&nbsp; &nbsp; <link rel="canonical" href="{{.Canonical}}" /></head><body>{{end}}{{define "footer"}}</body></html>{{end}}效果很好
打开App,查看更多内容
随时随地看视频慕课网APP