相关方法:
func (r *Response) WriteTpl(tpl string, params ...gview.Params) error
func (r *Response) WriteTplContent(content string, params ...gview.Params) error
func (r *Response) WriteTplDefault(params ...gview.Params) error
func (r *Response) ParseTpl(tpl string, params ...gview.Params) (string, error)
func (r *Response) ParseTplContent(content string, params ...gview.Params) (string, error)
func (r *Response) ParseTplDefault(params ...gview.Params) (string, error)
Response
支持模板文件/内容解析输出,或者模板文件/内容解析返回。与直接使用模板对象解析模板功能不同的是, Response
的解析支持一些请求相关的内置变量。模板解析包含以下方法:
WriteTpl*
方法用于模板输出,解析并输出模板文件,也可以直接解析并输出给定的模板内容。ParseTpl*
方法用于模板解析,解析模板文件或者模板内容,返回解析后的内容。
tip
解析模板时组件底层会自动通过 Request
对象获取当前链路的 Context
上下文变量并传递给模板引擎,因此开发者不用显示给模板引擎传递 Context
上下文变量。
内置变量
Config
访问默认的配置管理( config.toml
)对象配置项。
使用方式:
{{.Config.配置项}}
Cookie
访问当前请求的 Cookie
对象参数值。
使用方式:
{{.Cookie.键名}}
Session
访问当前请求的 Session
对象参数值。
使用方式:
{{.Session.键名}}
Query
访问当前 Query String
中的请求参数值。
使用方式:
{{.Query.键名}}
Form
访问当前表单请求参数值。
使用方式:
{{.Form.键名}}
Request
访问当前请求参数值(不区分参数提交方式)。
使用方式:
{{.Request.键名}}
使用示例
package main
import (
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/net/ghttp"
)
func main() {
s := g.Server()
s.BindHandler("/", func(r *ghttp.Request){
r.Cookie.Set("theme", "default")
r.Session.Set("name", "john")
content :=`Config:{{.Config.redis.cache}}, Cookie:{{.Cookie.theme}}, Session:{{.Session.name}}, Query:{{.Query.name}}`
r.Response.WriteTplContent(content, nil)
})
s.SetPort(8199)
s.Run()
}
其中, config.toml
内容为:
# Redis数据库配置
[redis]
disk = "127.0.0.1:6379,0"
cache = "127.0.0.1:6379,1"
执行后,访问 http://127.0.0.1:8199/?name=john ,输出结果为:
Config:127.0.0.1:6379,1, Cookie:default, Session:john, Query:john