自定义模板函数:
beego 支持用户自定义模板函数,但是必须在 beego.Run()
调用之前,设置如下:
func hello(in string)(out string){
out = in + "world"
return
}
//自定义 hi键 对应的模板函数为 hello()
beego.AddFuncMap("hi",hello)
定义之后你就可以在模板中这样使用了:
//对 .Content 内容使用 hi键 对应的 hello()函数进行过滤:
{{.Content | hi}}
内置模板函数:
目前 beego 内置的模板函数如下所示:
- dateformat
实现了时间的格式化,返回字符串。
使用方法 {{dateformat .Time “2006-01-02T15:04:05Z07:00”}} - date
实现了类似 PHP 的 date 函数,可以很方便的根据字符串返回时间。
使用方法 {{date .T “Y-m-d H:i:s”}} - compare
实现了比较两个对象的比较,如果相同返回 true,否者 false 。
使用方法 {{compare .A .B}} - substr
实现了字符串的截取,支持中文截取的完美截取。
使用方法 {{substr .Str 0 30}} - html2str
实现了把 html 转化为字符串,剔除一些 script、css 之类的元素,返回纯文本信息。
使用方法 {{html2str .Htmlinfo}} - str2html
实现了把相应的字符串当作 HTML 来输出,不转义。
使用方法 {{str2html .Strhtml}} - htmlquote
实现了基本的 html 字符转义。
使用方法 {{htmlquote .quote}} - htmlunquote
实现了基本的反转移字符。
使用方法 {{htmlunquote .unquote}} - renderform
根据 StructTag 直接生成对应的表单。
使用方法 {{&struct | renderform}} - assets_js
为 js 文件生成一个<script>
标签。
使用方法 {{assets_js src}} - assets_css
为 css 文件生成一个<link>
标签。
使用方法 {{assets_css src}} - config
获取 AppConfig 的值。
使用方法 {{config configType configKey defaultValue}} , 可选的 configType 有 String, Bool, Int, Int64, Float, DIY - map_get
获取map
的值。
使用用法:// In controller Data["m"] = map[string]interface{} { "a": 1, "1": map[string]float64{ "c": 4, }, } // In view {{ map_get m "a" }} // return 1 {{ map_get m 1 "c" }} // return 4
- urlfor
获取控制器方法的 URL。
使用用法:{{urlfor "TestController.List"}}