本文讲述 beego 中使用的模板语法,与 go 模板语法基本相同。

基本语法

go 统一使用了 {{ 和 }} 作为左右标签,没有其他的标签符号。如果您想要修改为其它符号,可以参考 模板标签。

使用 . 来访问当前位置的上下文

使用 $ 来引用当前模板根级的上下文

使用 $var 来访问创建的变量

[more]

模板中支持的 go 语言符号

{{"string"}} // 一般 string

{{`raw string`}} // 原始 string

{{'c'}} // byte

{{print nil}} // nil 也被支持

模板中的 pipeline

可以是上下文的变量输出,也可以是函数通过管道传递的返回值

{{. | FuncA | FuncB | FuncC}}

当 pipeline 的值等于:

false 或 0

nil 的指针或 interface

长度为 0 的 array, slice, map, string

那么这个 pipeline 被认为是空

if … else … end

{{if pipeline}}{{end}}

if 判断时,pipeline 为空时,相当于判断为 False

this.Data["IsLogin"] = true

this.Data["IsHome"] = true

this.Data["IsAbout"] = true

支持嵌套的循环

{{if .IsHome}}

{{else}}

{{if .IsAbout}}{{end}}

{{end}}

也可以使用 else if 进行

{{if .IsHome}}

{{else if .IsAbout}}

{{else}}

{{end}}

range … end

{{range pipeline}}{{.}}{{end}}

pipeline 支持的类型为 array, slice, map, channel

range 循环内部的 . 改变为以上类型的子元素

对应的值长度为 0 时,range 不会执行,. 不会改变

pages := []struct {

Num int

}{{10}, {20}, {30}}

this.Data["Total"] = 100

this.Data["Pages"] = pages

使用 .Num 输出子元素的 Num 属性,使用 $. 引用模板中的根级上下文

{{range .Pages}}

{{.Num}} of {{$.Total}}

{{end}}

使用创建的变量,在这里和 go 中的 range 用法是相同的。

{{range $index, $elem := .Pages}}

{{$index}} - {{$elem.Num}} - {{.Num}} of {{$.Total}}

{{end}}

range 也支持 else

{{range .Pages}}

{{else}}

{{/* 当 .Pages 为空 或者 长度为 0 时会执行这里 */}}

{{end}}

with … end

{{with pipeline}}{{end}}

with 用于重定向 pipeline

{{with .Field.NestField.SubField}}

{{.Var}}

{{end}}

也可以对变量赋值操作

{{with $value := "My name is %s"}}

{{printf . "slene"}}

{{end}}

with 也支持 else

{{with pipeline}}

{{else}}

{{/* 当 pipeline 为空时会执行这里 */}}

{{end}}

define

define 可以用来定义自模板,可用于模块定义和模板嵌套

{{define "loop"}}

{{.Name}}

{{end}}

使用 template 调用模板

{{range .Items}}

{{template "loop" .}}

{{end}}

template

{{template "模板名" pipeline}}

将对应的上下文 pipeline 传给模板,才可以在模板中调用

Beego 中支持直接载入文件模板

{{template "path/to/head.html" .}}

Beego 会依据你设置的模板路径读取 head.html

在模板中可以接着载入其他模板,对于模板的分模块处理很有用处

注释

允许多行文本注释,不允许嵌套

{{/* comment content

support new line */}}

基本函数

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

{{.Con | markdown | addlinks}}

{{.Name | printf "%s"}}

使用括号

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

and

{{and .X .Y .Z}}

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

call

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

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

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

index

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

this.Data["Maps"] = map[string]string{"name": "Beego"}

{{index .Maps "name"}}

len

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

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

not

not 返回输入参数的否定值,if true then false else true

or

{{or .X .Y .Z}}

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

print

对应 fmt.Sprint

printf

对应 fmt.Sprintf

println

对应 fmt.Sprintln

urlquery

{{urlquery "http://beego.me"}}

将返回

http%3A%2F%2Fbeego.me

eq / ne / lt / le / gt / ge

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

eq: arg1 == arg2

ne: arg1 != arg2

lt: arg1 < arg2

le: arg1 <= arg2

gt: arg1 > arg2

ge: arg1 >= arg2

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

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

与 if 一起使用

{{if eq true .Var1 .Var2 .Var3}}{{end}}

{{if lt 100 200}}{{end}}

更多文档请访问 beego 官网。

beego模板语法循环html块,1.69 beego 模板语法指南 - Beego 中文文档相关推荐

  1. thinkjs能在浏览器html文件,thinkjs框架的默认模板引擎Nunjucks的中文文档

    Node 端使用 $ npm install nunjucks 0 $npminstallnunjucks 下载后可直接 require('nunjucks') 使用 浏览器端使用 可直接使用 nun ...

  2. 284页beego官方中文文档,Go语言进阶必备

    Go语言作为出身名门的后起之秀,大家所熟知的Docker和Kubernets(K8S)就是使用Go语言开发的,以其简单高效.高并发.跨平台的优势,称霸于容器领域. 根据 Stack Overflow ...

  3. python中文语法提示_Python官方中文文档上线了:各种教程已汉化,不用再苦等野生翻译...

    终于,Python有官方中文文档了. 从今往后,不论是版本新变化,入门教程,语法讲解,Python模块安装指南--各种各样的手册,都可以直接看中文了. △ 不是谷歌翻译哟 你看,比起英文原版,中文的语 ...

  4. beego 例子_Beego中文文档PDF

    [实例简介] Beego中文文档PDF版,便于平板上阅读查看....... 快速入门」 快速入门 安装 brego包含一些示例应用程序以帮您学习并使用 brego应用框架 您需要安装Go1.1+以确保 ...

  5. beego模板语法循环html块,beego 模版语法

    beego 模板语法指南 本文讲述 beego 中使用的模板语法,与 go 模板语法基本相同. 基本语法 go 统一使用了 {{ 和 }} 作为左右标签,没有其他的标签符号.如果您想要修改为其它符号, ...

  6. .blade.php,Blade 模板 |《Laravel 5.4 中文文档 5.4》| Laravel China 社区

    本文档最新版为 8.x,旧版本可能放弃维护,推荐阅读最新版! Laravel 的 Blade 模板引擎 简介 Blade 是 Laravel 提供的一个既简单又强大的模板引擎.和其他流行的 PHP 模 ...

  7. Theano 中文文档 0.9 - 7.2.5 循环

    7.2.5 循环 译者:Python 文档协作翻译小组,原文:Loop. 本文以 CC BY-NC-SA 4.0 协议发布,转载请保留作者署名和文章出处. Python 文档协作翻译小组人手紧缺,有兴 ...

  8. AUTOIT 3.0 基本语法:参考中文文档

    $var = 20 If $var > 10 Then     MsgBox(0, "示例", $var & " 果真大于 10!^_^") El ...

  9. 【中文模板】Latex如何写中文文档

    \documentclass[UTF8]{ctexart}\begin{document}你好Latex!\end{document}

最新文章

  1. 多线程实现生产者消费者模型
  2. hive 修改分桶数 分桶表_Hive中的分桶
  3. 在Servlet中实现页面重定向
  4. 菜鸟谈算法和数学对写程序的影响
  5. document.write() 和writeln()方法注意事项
  6. 你看到过哪些简短有内涵的一看就想发朋友圈的句子?
  7. VS2005 工程在win7下使用管理员权限运行
  8. db2数据库基础知识
  9. 实用工具SDelete
  10. PR13.0 2019 导入图片仅显示部分解决方法
  11. RocketMQ创建topic流程解析
  12. 英特尔至强处理器排行_英特尔赛扬Vs之间的比较。 至强处理器
  13. 【python】如何批量修改文件名
  14. ESP32-S3-WROOM-1-N16R8 配置PSRAM
  15. 安卓手机上最好的3个txt阅读器
  16. SISD、MIMD、SIMD、MISD系统介绍
  17. 【Zotero】与坚果云配合使用同步失败解决方法
  18. 用户体验 | 深耕用户体验筑造银行竞争的护城河
  19. 【Qt】动态刷新lcdNumber显示的值
  20. TokenGazer评级丨MakerDao:去中心化金融趋势确立,项目治理恐有中心化风险

热门文章

  1. Python入门学习笔记(9)
  2. 微信小程序 ----- this.getOpenerEventChannel is not a function
  3. NiosII软处理器快速入门- 10分钟学会NiosII(1)
  4. BZOJ 1070: [SCOI2007]修车(费用流)
  5. 子类既要实现接口又要继承抽象类的一个demo
  6. css基础内容之background
  7. Android中图片的处理(放大缩小,去色,转换格式,增加水印等)(转)
  8. wxWidgets事件处理(手机播放器连载系列2)
  9. JavaScript——编码问题
  10. 新装Windows 2003 + IIS 6.0的问题