# beego 模板語法指南
本文講述 beego 中使用的模板語法,與 go 模板語法基本相同。
## 基本語法
go 統一使用了 `{{` 和 `}}` 作為左右標簽,沒有其他的標簽符號。如果您想要修改為其它符號,可以參考 [模板標簽](./view.md)。
使用 `.` 來訪問當前位置的上下文
使用 `$` 來引用當前模板根級的上下文
使用 `$var` 來訪問創建的變量
**模板中支持的 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"}}
<li>{{.Name}}</li>
{{end}}
```
使用 template 調用模板
```
<ul>
{{range .Items}}
{{template "loop" .}}
{{end}}
</ul>
```
#### 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 官網](http://beego.me/docs/mvc/view/view.md)。
- beego簡介
- 為 beego 貢獻
- 發布版本
- 升級指南
- beego安裝升級
- Bee 工具的使用
- 快速入門
- 新建項目
- 路由設置
- Controller 運行機制
- model 邏輯
- view 編寫
- 靜態文件處理
- beego 的 MVC 架構介紹
- controller 設計
- 參數配置
- 路由設置
- 控制器函數
- XSRF 過濾
- 請求數據處理
- session 控制
- 過濾器
- flash 數據
- URL構建
- 多種格式數據輸出
- 表單數據驗證
- 錯誤處理
- 日志處理
- model設計
- 概述
- ORM 使用
- CRUD 操作
- 高級查詢
- 原生 SQL 查詢
- 構造查詢
- 事務處理
- 模型定義
- 命令模式
- 測試用例
- 自定義字段
- FAQ
- view 設計
- 模板語法指南
- 模板處理
- 模板函數
- 靜態文件處理
- 模板分頁處理
- beego 的模塊設計
- session 模塊
- grace 模塊
- cache 模塊
- logs 模塊
- httplib 模塊
- context 模塊
- toolbox 模塊
- config 模塊
- i18n 模塊
- beego 高級編程
- 進程內監控
- API 自動化文檔
- 應用部署
- 獨立部署
- supervisor 部署
- Nginx 部署
- apache 部署
- beego 第三方庫
- 應用例子
- 在線聊天室
- 短域名服務
- Todo 列表
- beego實用庫
- 驗證碼
- 分頁
- FAQ