W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
本文講述 beego 中使用的模板語法,與 go 模板語法基本相同。
go 統(tǒng)一使用了 {{ 和 }} 作為左右標簽,沒有其他的標簽符號。如果您想要修改為其它符號,可以參考 模板標簽。
使用 . 來訪問當前位置的上下文
使用 $ 來引用當前模板根級的上下文
使用 $var 來訪問創(chuàng)建的變量
[more]
模板中支持的 go 語言符號
{{"string"}} // 一般 string
{{`raw string`}} // 原始 string
{{'c'}} // byte
{{print nil}} // nil 也被支持
模板中的 pipeline
可以是上下文的變量輸出,也可以是函數(shù)通過管道傳遞的返回值
{{. | FuncA | FuncB | FuncC}}
當 pipeline 的值等于:
那么這個 pipeline 被認為是空
{{if pipeline}}{{end}}
if 判斷時,pipeline 為空時,相當于判斷為 False
this.Data["IsLogin"] = true
this.Data["IsHome"] = true
this.Data["IsAbout"] = true
支持嵌套的循環(huán)
{{if .IsHome}}
{{else}}
{{if .IsAbout}}{{end}}
{{end}}
也可以使用 else if 進行
{{if .IsHome}}
{{else if .IsAbout}}
{{else}}
{{end}}
{{range pipeline}}{{.}}{{end}}
pipeline 支持的類型為 array, slice, map, channel
range 循環(huán)內(nèi)部的 . 改變?yōu)橐陨项愋偷淖釉?/p>
對應的值長度為 0 時,range 不會執(zhí)行,. 不會改變
pages := []struct {
Num int
}{{10}, {20}, {30}}
this.Data["Total"] = 100
this.Data["Pages"] = pages
使用 .Num 輸出子元素的 Num 屬性,使用 $. 引用模板中的根級上下文
{{range .Pages}}
{{.Num}} of {{$.Total}}
{{end}}
使用創(chuàng)建的變量,在這里和 go 中的 range 用法是相同的。
{{range $index, $elem := .Pages}}
{{$index}} - {{$elem.Num}} - {{.Num}} of {{$.Total}}
{{end}}
range 也支持 else
{{range .Pages}}
{{else}}
{{/* 當 .Pages 為空 或者 長度為 0 時會執(zhí)行這里 */}}
{{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 為空時會執(zhí)行這里 */}}
{{end}}
define 可以用來定義自模板,可用于模塊定義和模板嵌套
{{define "loop"}}
<li>{{.Name}}</li>
{{end}}
使用 template 調(diào)用模板
<ul>
{{range .Items}}
{{template "loop" .}}
{{end}}
</ul>
{{template "模板名" pipeline}}
將對應的上下文 pipeline 傳給模板,才可以在模板中調(diào)用
Beego 中支持直接載入文件模板
{{template "path/to/head.html" .}}
Beego 會依據(jù)你設置的模板路徑讀取 head.html
在模板中可以接著載入其他模板,對于模板的分模塊處理很有用處
允許多行文本注釋,不允許嵌套
{{/* comment content
support new line */}}
變量可以使用符號 | 在函數(shù)間傳遞
{{.Con | markdown | addlinks}}
{{.Name | printf "%s"}}
使用括號
{{printf "nums is %s %d" (printf "%d %d" 1 2) 3}}
{{and .X .Y .Z}}
and 會逐一判斷每個參數(shù),將返回第一個為空的參數(shù),否則就返回最后一個非空參數(shù)
{{call .Field.Func .Arg1 .Arg2}}
call 可以調(diào)用函數(shù),并傳入?yún)?shù)
調(diào)用的函數(shù)需要返回 1 個值 或者 2 個值,返回兩個值時,第二個值用于返回 error 類型的錯誤。返回的錯誤不等于 nil 時,執(zhí)行將終止。
index 支持 map, slice, array, string,讀取指定類型對應下標的值
this.Data["Maps"] = map[string]string{"name": "Beego"}
{{index .Maps "name"}}
{{printf "The content length is %d" (.Content|len)}}
返回對應類型的長度,支持類型:map, slice, array, string, chan
not 返回輸入?yún)?shù)的否定值,if true then false else true
{{or .X .Y .Z}}
or 會逐一判斷每個參數(shù),將返回第一個非空的參數(shù),否則就返回最后一個參數(shù)
對應 fmt.Sprint
對應 fmt.Sprintf
對應 fmt.Sprintln
{{urlquery "http://beego.me"}}
將返回
http%3A%2F%2Fbeego.me
這類函數(shù)一般配合在 if 中使用
eq: arg1 == arg2 ne: arg1 != arg2 lt: arg1 < arg2 le: arg1 <= arg2 gt: arg1 > arg2 ge: arg1 >= arg2
eq 和其他函數(shù)不一樣的地方是,支持多個參數(shù),和下面的邏輯判斷相同
arg1==arg2 || arg1==arg3 || arg1==arg4 ...
與 if 一起使用
{{if eq true .Var1 .Var2 .Var3}}{{end}}
{{if lt 100 200}}{{end}}
更多文檔請訪問 beego 官網(wǎng)。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: