内容简介:golang template使用自定义函数需求来源是这样的:如何拿到一个slice的最后一个元素在模版里面,我们可以获取slice的任意元素,只要给定下标即可,例如:
golang template使用自定义函数
需求来源是这样的:如何拿到一个slice的最后一个元素
在模版里面,我们可以获取slice的任意元素,只要给定下标即可,例如:
package main import ( "os" "log" "text/template" ) const templateText = ` Friends : {{.Friends}} 1st Friend : {{index .Friends 0}} 2nd Friend : {{index .Friends 1}} 3rd Friend : {{index .Friends 2}} ` func main() { type Recipient struct { Name string Friends []string } recipient := Recipient{ Name : "Jack", Friends : []string {"Bob", "Json", "Tom"}, } t := template.Must(template.New("").Parse(templateText)) err := t.Execute(os.Stdout, recipient) if err != nil { log.Println("Executing template:", err) } }
运行:
Friends : [Bob Json Tom] 1st Friend : Bob 2nd Friend : Json 3rd Friend : Tom
然而,如何获取最后一个元素呢?因为这个下标不是一个常量,是根据slice大小动态变化的。
我们首先会想到使用len(.Friends)行不行?
const templateText = ` Nrd Friend : {{index .Friends (len .Friends)}} `
执行模版会报错:
Executing template: template: :<line>:<column>: executing "" at <index .Friends (len .Friends)>: error calling index: index out of range: 3
因为slice最后一个元素下标是(len()-1),看来用一个算术运行就可以了,遗憾的是golang template并没有提供简单的加减运算,也没有相应的函数(golang template的所有系统函数都在这儿: https://golang.org/pkg/text/template/#hdr-Functions
);所以我们必须自定义一个减函数(sub)
const templateText = ` Nrd Friend : {{index .Friends (sub (len .Friends) 1)}} ` templateFunc := map[string]interface{} { "sub": func(a, b int) int { return a - b }, } t := template.Must(template.New("").Funcs(template.FuncMap(templateFunc)).Parse(templateText))
运行结果:
Nrd Friend : Tom
可见函数sub起效了。
这里我们定义的是通用的add/sub函数,那么我们能不能直接定义last函数呢,返回slice的最后一个元素:
const templateText = ` Nrd Friend : {{last .Friends}} ` templateFunc := map[string]interface{} { "last": func(s []interface{}) interface{} { return s[len(s)-1] }, } t := template.Must(template.New("").Funcs(template.FuncMap(templateFunc)).Parse(templateText))
运行:
Executing template: template: :<line>:<column>: executing "" at <.Friends>: wrong type for value; expected []interface {}; got []string
是不是很遗憾,为啥通用类型interface{}不支持呢,一定要具体类型吗?我们重新定义last函数:
templateFunc := map[string]interface{} { "last": func(s []string) string { return s[len(s)-1] }, }
再运行:
Nrd Friend : Tom
竟然好了。这个说来我觉得还是有点遗憾了,为啥不支持通用类型interface{}呢,本来slice取其中的元素操作本身并不需要关系元素类型,用interface{}是很好的方法。
抱怨归抱怨,我也没有办法,只能遵从这个设计吧。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Python 函数调用&定义函数&函数参数
- 不同语言在函数内部定义函数
- Shell编程—【04】函数的定义、参数、变量作用域、函数库
- Laravel 增加自定义全局函数
- 在 Go 语言中定义函数
- Golang中的自定义函数
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
About Face 4: 交互设计精髓
[美] 艾伦·库伯、[美] 罗伯特·莱曼、[美] 戴维·克罗宁、[美] 克里斯托弗·诺埃塞尔 / 倪卫国、刘松涛、杭敏、薛菲 / 电子工出版社 / 2015-10 / 118.00元
《About Face 4: 交互设计精髓》是《About Face 3:交互设计精髓》的升级版,此次升级把全书的结构重组优化,更加精练和易用;更新了一些适合当下时代的术语和实例,文字全部重新编译,更加清晰易读;增加了更多目标导向设计过程的细节,更新了现行实践,重点增加 移动和触屏平台交互设计,其实《About Face 4: 交互设计精髓》多数内容适用于多种平台。 《About F......一起来看看 《About Face 4: 交互设计精髓》 这本书的介绍吧!