# 模板函数

Beego 支持用户定义模板函数,但是必须在 web.Run() 调用之前,设置如下:

func hello(in string)(out string){
    out = in + "world"
    return
}

web.AddFuncMap("hi",hello)
1
2
3
4
5
6

定义之后你就可以在模板中这样使用了:

{{.Content | hi}}
1

目前 Beego 内置的模板函数如下所示:

  • dateformat

    实现了时间的格式化,返回字符串,使用方法

    {{dateformat .Time "2006-01-02T15:04:05Z07:00"}}
    
    1
  • date

    实现了类似 PHP 的 date 函数,可以很方便的根据字符串返回时间,使用方法:

    {{date .T "Y-m-d H:i:s"}}
    
    1
  • compare

    实现了比较两个对象的比较,如果相同返回 true,否者 false,使用方法

    {{compare .A .B}}
    
    1
  • substr

    实现了字符串的截取,支持中文截取的完美截取,使用方法

    {{substr .Str 0 30}}
    
    1
  • html2str

    实现了把 html 转化为字符串,剔除一些 script、css 之类的元素,返回纯文本信息,使用方法

    {{html2str .Htmlinfo}}
    
    1
  • str2html

    实现了把相应的字符串当作 HTML 来输出,不转义,使用方法

    {{str2html .Strhtml}}
    
    1
  • htmlquote

    实现了基本的 html 字符转义,使用方法

    {{htmlquote .quote}}
    
    1
  • htmlunquote

    实现了基本的反转移字符,使用方法

    {{htmlunquote .unquote}}
    
    1
  • renderform

    根据 StructTag 直接生成对应的表单,使用方法

    {{&struct | renderform}}
    
    1
  • assets_js

    为 js 文件生成一个 <script> 标签. 使用方法

    {{assets_js src}}
    
    1
  • assets_css

    为 css 文件生成一个 <link> 标签. 使用方法

    {{assets_css src}}
    
    1
  • config

    获取 AppConfig 的值. 使用方法

    {{config configType configKey defaultValue}}
    
    1

    可选的 configTypeString, 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
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
  • urlfor

    获取控制器方法的 URL

    {{urlfor "TestController.List"}}
    
    1