./view/user/user 里面的继承了 ./view/template/master 模板
./view/template/master 模板 代码
<!DOCTYPE html> <html> <head> </head> <body> <p>模板上面内容</p> {{block "context" .}}{{end}} <p>模板下面内容</p> {{ say "<div style="background-color:red;">你好</div>" }} </body> </html>
./view/user/user 代码
{{template "master" .}} {{define "context"}} {{"<div style="background-color:red;">你好</div>" |say}} {{.title}} <p>user内容</p> {{end}}
main() 里面的后台代码,注意:
engin.SetFuncMap(template.FuncMap{"say":say,})
engin.LoadHTMLFiles("./view/template/master", "./view/user/user")
package main import ( "github.com/gin-gonic/gin" "html/template" "net/http" ) // 通过该方法可以将内容以HTML的形式输出 func say(s string) template.HTML { return template.HTML(s) } func main(){ engin :=gin.Default() engin.GET("/user", func(c *gin.Context) { // 设置 FuncMap 即前端可以调用的方法 engin.SetFuncMap(template.FuncMap{"say":say,}) // 解析模板 engin.LoadHTMLFiles("./view/template/master", "./view/user/user") // 渲染模板 c.HTML(http.StatusOK,"user",gin.H{"title":"中间内容",}) }) engin.GET("/ouser", func(c *gin.Context) { engin.LoadHTMLFiles("./view/myuser/user") c.HTML(http.StatusOK,"user",gin.H{"title":"你好另一个User",}) }) engin.Run() }
关于Gin框架 返回Json的实例
package main import ( "github.com/gin-gonic/gin" "html/template" "net/http" ) type User struct { UserId string UserName string } func main(){ engin :=gin.Default() engin.GET("/userinfo", func(c *gin.Context) { user :=&User{UserId: "1",UserName: "张三"}
// Gin 会自动将User转换成JSon返回给前端,其他像Map,slice也一样 c.JSON(http.StatusOK,user) }) engin.Run() }