beego模板語法指南

2023-11-21 10:45 更新

本文講述 beego 中使用的模板語法,與 go 模板語法基本相同。

基本語法

go 統(tǒng)一使用了 {{ 和 }} 作為左右標(biāo)簽,沒有其他的標(biāo)簽符號(hào)。如果您想要修改為其它符號(hào),可以參考 模板標(biāo)簽

使用 . 來訪問當(dāng)前位置的上下文

使用 $ 來引用當(dāng)前模板根級(jí)的上下文

使用 $var 來訪問創(chuàng)建的變量

[more]

模板中支持的 go 語言符號(hào)

{{"string"}} // 一般 string
{{`raw string`}} // 原始 string
{{'c'}} // byte
{{print nil}} // nil 也被支持

模板中的 pipeline

可以是上下文的變量輸出,也可以是函數(shù)通過管道傳遞的返回值

{{. | FuncA | FuncB | FuncC}}

當(dāng) pipeline 的值等于:

  • false 或 0
  • nil 的指針或 interface
  • 長度為 0 的 array, slice, map, string

那么這個(gè) pipeline 被認(rèn)為是空

if ... else ... end

{{if pipeline}}{{end}}

if 判斷時(shí),pipeline 為空時(shí),相當(dāng)于判斷為 False

this.Data["IsLogin"] = true
this.Data["IsHome"] = true
this.Data["IsAbout"] = true

支持嵌套的循環(huán)

{{if .IsHome}}
{{else}}
    {{if .IsAbout}}{{end}}
{{end}}

也可以使用 else if 進(jìn)行

{{if .IsHome}}
{{else if .IsAbout}}
{{else}}
{{end}}

range ... end

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

pipeline 支持的類型為 array, slice, map, channel

range 循環(huán)內(nèi)部的 . 改變?yōu)橐陨项愋偷淖釉?/p>

對(duì)應(yīng)的值長度為 0 時(shí),range 不會(huì)執(zhí)行,. 不會(huì)改變

pages := []struct {
    Num int
}{{10}, {20}, {30}}

this.Data["Total"] = 100
this.Data["Pages"] = pages

使用 .Num 輸出子元素的 Num 屬性,使用 $. 引用模板中的根級(jí)上下文

{{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}}
    {{/* 當(dāng) .Pages 為空 或者 長度為 0 時(shí)會(huì)執(zhí)行這里 */}}
{{end}}

with ... end

{{with pipeline}}{{end}}

with 用于重定向 pipeline

{{with .Field.NestField.SubField}}
    {{.Var}}
{{end}}

也可以對(duì)變量賦值操作

{{with $value := "My name is %s"}}
    {{printf . "slene"}}
{{end}}

with 也支持 else

{{with pipeline}}
{{else}}
    {{/* 當(dāng) pipeline 為空時(shí)會(huì)執(zhí)行這里 */}}
{{end}}

define

define 可以用來定義自模板,可用于模塊定義和模板嵌套

{{define "loop"}}
    <li>{{.Name}}</li>
{{end}}

使用 template 調(diào)用模板

<ul>
    {{range .Items}}
        {{template "loop" .}}
    {{end}}
</ul>

template

{{template "模板名" pipeline}}

將對(duì)應(yīng)的上下文 pipeline 傳給模板,才可以在模板中調(diào)用

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

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

Beego 會(huì)依據(jù)你設(shè)置的模板路徑讀取 head.html

在模板中可以接著載入其他模板,對(duì)于模板的分模塊處理很有用處

注釋

允許多行文本注釋,不允許嵌套

{{/* comment content
support new line */}}

基本函數(shù)

變量可以使用符號(hào) | 在函數(shù)間傳遞

{{.Con | markdown | addlinks}}
{{.Name | printf "%s"}}

使用括號(hào)

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

and

{{and .X .Y .Z}}

and 會(huì)逐一判斷每個(gè)參數(shù),將返回第一個(gè)為空的參數(shù),否則就返回最后一個(gè)非空參數(shù)

call

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

call 可以調(diào)用函數(shù),并傳入?yún)?shù)

調(diào)用的函數(shù)需要返回 1 個(gè)值 或者 2 個(gè)值,返回兩個(gè)值時(shí),第二個(gè)值用于返回 error 類型的錯(cuò)誤。返回的錯(cuò)誤不等于 nil 時(shí),執(zhí)行將終止。

index

index 支持 map, slice, array, string,讀取指定類型對(duì)應(yīng)下標(biāo)的值

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

len

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

返回對(duì)應(yīng)類型的長度,支持類型:map, slice, array, string, chan

not

not 返回輸入?yún)?shù)的否定值,if true then false else true

or

{{or .X .Y .Z}}

or 會(huì)逐一判斷每個(gè)參數(shù),將返回第一個(gè)非空的參數(shù),否則就返回最后一個(gè)參數(shù)

print

對(duì)應(yīng) fmt.Sprint

printf

對(duì)應(yīng) fmt.Sprintf

println

對(duì)應(yīng) fmt.Sprintln

urlquery

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

將返回

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

eq / ne / lt / le / gt / ge

這類函數(shù)一般配合在 if 中使用

eq: arg1 == arg2 ne: arg1 != arg2 lt: arg1 < arg2 le: arg1 <= arg2 gt: arg1 > arg2 ge: arg1 >= arg2

eq 和其他函數(shù)不一樣的地方是,支持多個(gè)參數(shù),和下面的邏輯判斷相同

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

與 if 一起使用

{{if eq true .Var1 .Var2 .Var3}}{{end}}
{{if lt 100 200}}{{end}}
更多文檔請(qǐng)?jiān)L問 beego 官網(wǎng)。
以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)