一个布局模板和三个子模板。
layout.html
<html> <body> {{template "tags"}} {{template "content"}} {{template "comment"}} </body> </html>
tags.html
{{define "tags"}} <div> {{.Name}} <div> {{end}}
content.html
{{define "content"}} <div> <p>{{.Title}}</p> <p>{{.Content}}</p> </div> {{end}}
comment.html
{{define "tags"}} <div> {{.Note}} </div> {{end}}
type Tags struct { Id int Name string } type Content struct { Id int Title string Content string } type Comment struct { Id int Note string } func main() { tags := &Tags{"Id":1, "Name":"golang"} Content := &Content{"Id":9, "Title":"Hello", "Content":"World!"} Comment := &Comment{"Id":2, "Note":"Good Day!"} }
我很困惑如何渲染每个子模板并将结果组合到布局输出中。
谢谢。
与往常一样,该文档是一个很好的起点。
我在操场上写了一个工作实例
解释一下:
&Tags{Id: 1}
&Tags{"Id":1}
{{template <name> <arg>}}
Page
map[string]interface{}
ResponseWriter
以及整个代码:
package main import "fmt" import "html/template" import "os" var page = `<html> <body> {{template "tags" .Tags}} {{template "content" .Content}} {{template "comment" .Comment}} </body> </html>` var tags = `{{define "tags"}} <div> {{.Name}} <div> {{end}}` var content = `{{define "content"}} <div> <p>{{.Title}}</p> <p>{{.Content}}</p> </div> {{end}}` var comment = `{{define "comment"}} <div> {{.Note}} </div> {{end}}` type Tags struct { Id int Name string } type Content struct { Id int Title string Content string } type Comment struct { Id int Note string } type Page struct { Tags *Tags Content *Content Comment *Comment } func main() { pagedata := &Page{Tags:&Tags{Id:1, Name:"golang"}, Content: &Content{Id:9, Title:"Hello", Content:"World!"}, Comment: &Comment{Id:2, Note:"Good Day!"}} tmpl := template.New("page") var err error if tmpl, err = tmpl.Parse(page); err != nil { fmt.Println(err) } if tmpl, err = tmpl.Parse(tags); err != nil { fmt.Println(err) } if tmpl, err = tmpl.Parse(comment); err != nil { fmt.Println(err) } if tmpl, err = tmpl.Parse(content); err != nil { fmt.Println(err) } tmpl.Execute(os.Stdout, pagedata) }