Scratch
Syntax
SHORTCODE.Scratch
Returns
maps.Scratch
在一个短代码中,Scratch
方法用于创建一个 scratch pad 来存储和操作数据。scratch pad 的作用范围仅限于该短代码,在服务器重建时会被重置。
方法
- Set
- 设置给定键的值。
{{ .Scratch.Set "greeting" "Hello" }}
- Get
- 获取给定键的值。
{{ .Scratch.Set "greeting" "Hello" }}
{{ .Scratch.Get "greeting" }} → Hello
- Add
- 将给定值添加到给定键的现有值之中。
-
对于单个值,
Add
接受支持 Go 的+
运算符的值。如果首个Add
是数组或切片,后续的添加将附加到该列表之后。
{{ .Scratch.Set "greeting" "Hello" }}
{{ .Scratch.Add "greeting" "Welcome" }}
{{ .Scratch.Get "greeting" }} → HelloWelcome
{{ .Scratch.Set "total" 3 }}
{{ .Scratch.Add "total" 7 }}
{{ .Scratch.Get "total" }} → 10
{{ .Scratch.Set "greetings" (slice "Hello") }}
{{ .Scratch.Add "greetings" (slice "Welcome" "Cheers") }}
{{ .Scratch.Get "greetings" }} → [Hello Welcome Cheers]
- SetInMap
- 接受
key
、mapKey
和value
,并将mapKey
和value
的映射添加到给定key
。
{{ .Scratch.SetInMap "greetings" "english" "Hello" }}
{{ .Scratch.SetInMap "greetings" "french" "Bonjour" }}
{{ .Scratch.Get "greetings" }} → map[english:Hello french:Bonjour]
- DeleteInMap
- 接受
key
和mapKey
,并从给定key
中移除mapKey
的映射。
{{ .Scratch.SetInMap "greetings" "english" "Hello" }}
{{ .Scratch.SetInMap "greetings" "french" "Bonjour" }}
{{ .Scratch.DeleteInMap "greetings" "english" }}
{{ .Scratch.Get "greetings" }} → map[french:Bonjour]
- GetSortedMapValues
- 按
mapKey
对key
中的值进行排序,并返回一个值数组。
{{ .Scratch.SetInMap "greetings" "english" "Hello" }}
{{ .Scratch.SetInMap "greetings" "french" "Bonjour" }}
{{ .Scratch.GetSortedMapValues "greetings" }} → [Hello Bonjour]
- Delete
- 移除给定的键。
{{ .Scratch.Set "greeting" "Hello" }}
{{ .Scratch.Delete "greeting" }}