beego支持的模板函数不是很多,有时候前端展现数据的时候,要对数据进行格式化,所以要用到自定义模板函数

比如我的前端模板上有时间和模板大小这2个数据,原始数据都是int的时间戳和byte单位的数据,我们要更友好的展示这些数据,就要对这些数据进行格式化

效果是这样的,可以看到时间和大小这2列已经是友好的显示方式

beego

前端模板中代码是这样的

<td>
{{substr $v.ID 0 12}}
</td>
<td>
{{$v.RepoTags}}
</td>

<td>
{{$v.Created | convertt}}
</td>

<td>
{{$v.VirtualSize | convertm}} M
</td>

分别通过convertt和convertm这2个函数进行数据转换, 注意:必须在 beego.Run() 调用之前

package main

import (
	_ "DockerAdmin/models"
	_ "DockerAdmin/routers"
	"fmt"
	"github.com/astaxie/beego"
	"time"
)

func convertM(in int64) (out int64) {
	out = in / 1000000
	return
}
func convertT(in int64) (out string) {
	tm := time.Unix(in, 0)
	out = tm.Format("2006-01-02 03:04:05 PM")
	return
}
func main() {

	beego.AddFuncMap("convertm", convertM)
	beego.AddFuncMap("convertt", convertT)
	beego.Run()
}

你可能会好奇,为什么格式字符串的时候,用的是2006-01-02这种格式。其实在Go 里,这些数字都是有特殊函义的,不是随便指定的数字,见下面列表:

月份 1,01,Jan,January

日  2,02,_2

时  3,03,15,PM,pm,AM,am

分  4,04

秒  5,05

年  06,2006

周几 Mon,Monday

时区时差表示 -07,-0700,Z0700,Z07:00,-07:00,MST

时区字母缩写 MST

当然beego还是有一些内置模板函数的,我用dateformat 没有成功,所以使用了自定义函数

  • dateformat实现了时间的格式化,返回字符串,使用方法 {{dateformat .Time “2006-01-02T15:04:05Z07:00”}}。
  • date实现了类似 PHP 的 date 函数,可以很方便的根据字符串返回时间,使用方法 {{date .T “Y-m-d H:i:s”}}。
  • compare实现了比较两个对象的比较,如果相同返回 true,否者 false,使用方法 {{compare .A .B}}。
  • substr实现了字符串的截取,支持中文截取的完美截取,使用方法 {{substr .Str 0 30}}。
  • html2str实现了把 html 转化为字符串,剔除一些 script、css 之类的元素,返回纯文本信息,使用方法 {{html2str .Htmlinfo}}。
  • str2html实现了把相应的字符串当作 HTML 来输出,不转义,使用方法 {{str2html .Strhtml}}。
  • htmlquote实现了基本的 html 字符转义,使用方法 {{htmlquote .quote}}。
  • htmlunquote实现了基本的反转移字符,使用方法 {{htmlunquote .unquote}}。
  • renderform根据 StructTag 直接生成对应的表单,使用方法 {{&struct | renderform}}。