基本函数

变量可以使用符号 | 在函数间传递

  1. {{.value | Func1 | Func2}}

使用括号

  1. {{printf "nums is %s %d" (printf "%d %d" 1 2) 3}}

and

  1. {{and .X .Y .Z}}

and会逐一判断每个参数,将返回第一个为空的参数,否则就返回最后一个非空参数

call

  1. {{call .Field.Func .Arg1 .Arg2}}

call可以调用函数,并传入参数

调用的函数需要返回 1 个值 或者 2 个值,返回两个值时,第二个值用于返回error类型的错误。返回的错误不等于nil时,执行将终止。

index

index支持map, slice, array, string,读取指定类型对应下标的值。

  1. {{index .Maps "name"}}

len

  1. {{printf "The content length is %d" (.Content|len)}}

返回对应类型的长度,支持类型:map, slice, array, string, chan

not

not返回输入参数的否定值。

or

  1. {{or .X .Y .Z}}

or会逐一判断每个参数,将返回第一个非空的参数,否则就返回最后一个参数。

print

对应fmt.Sprint

printf

对应fmt.Sprintf

println

对应fmt.Sprintln

urlquery

  1. {{urlquery "http://johng.cn"}}

将返回

  1. http%3A%2F%2Fjohng.cn

eq / ne / lt / le / gt / ge

这类函数一般配合在if中使用

  1. `eq`: arg1 == arg2
  2. `ne`: arg1 != arg2
  3. `lt`: arg1 < arg2
  4. `le`: arg1 <= arg2
  5. `gt`: arg1 > arg2
  6. `ge`: arg1 >= arg2

eq和其他函数不一样的地方是,支持多个参数,和下面的逻辑判断相同

  1. arg1==arg2 || arg1==arg3 || arg1==arg4 ...

if一起使用

  1. {{if eq true .Var1 .Var2 .Var3}}...{{end}}
  1. {{if lt 100 200}}...{{end}}

内置函数

text

  1. {{.value | text}}

value变量值去掉HTML标签,仅显示文字内容(并且去掉script标签)。

html

在默认情况下,模板引擎会将输出的字符串内容进行HTML转义处理,使用html内置函数可以保留HTML标签,并显示完整的HTML内容。

  1. {{.value | html}}

value变量值保留HTML标签,显示完整的HTML内容(并且会保留script标签)。

使用示例:

  1. package main
  2. import (
  3. "gitee.com/johng/gf/g/os/gview"
  4. "gitee.com/johng/gf/g"
  5. )
  6. func main() {
  7. if c, err := gview.ParseContent(`{{"<div>测试</div>模板引擎默认处理HTML标签<script>alert(\"test\");</script>\n"}}`, nil); err == nil {
  8. g.Dump(c)
  9. } else {
  10. g.Dump(c)
  11. }
  12. if c, err := gview.ParseContent(`{{"<div>测试</div>去掉HTML标签<script>alert(\"test\");</script>\n"|text}}`, nil); err == nil {
  13. g.Dump(c)
  14. } else {
  15. g.Dump(c)
  16. }
  17. if c, err := gview.ParseContent(`{{"<div>测试</div>保留HTML标签<script>alert(\"test\");</script>\n"|html}}`, nil); err == nil {
  18. g.Dump(c)
  19. } else {
  20. g.Dump(c)
  21. }
  22. }

执行后,输出结果为:

  1. &lt;div&gt;测试&lt;/div&gt;模板引擎默认处理HTML标签&lt;script&gt;alert(&#34;test&#34;);&lt;/script&gt;
  2. 测试去掉HTML标签
  3. <div>测试</div>保留HTML标签<script>alert("test");</script>

get

仅在Web Server下,即通过ghttp模块使用ghttp.Response/gmvc.View对象渲染模板引擎时有效。

  1. {{get "参数名称"}}

用于获取GET方式传递的参数。

使用示例:

  1. {{if (get "name")}}
  2. {{get "name"}}
  3. {{else}}
  4. NoName
  5. {{end}}

post

仅在Web Server下,即通过ghttp模块使用ghttp.Response/gmvc.View对象渲染模板引擎时有效。

  1. {{post "参数名称"}}

用于获取POST方式传递的参数。

request

仅在Web Server下,即通过ghttp模块使用ghttp.Response/gmvc.View对象渲染模板引擎时有效。

  1. {{request "参数名称"}}

用于获取路由参数,以及GET/POST方式传递的参数。