基本介绍

主要用于嵌入到用户自定义的结构体中,并且通过标签的形式给gmeta包的结构体打上自定义的标签内容(元数据),并在运行时可以特定方法动态获取这些自定义的标签内容。

gmeta内部使用了缓存特性,因此获取元数据的执行效率非常高效。

使用方式:

  1. import "github.com/gogf/gf/util/gmeta"

接口文档

https://pkg.go.dev/github.com/gogf/gf/util/gmeta

方法列表:

  1. func Data(object interface{}) map[string]interface{}
  2. func Get(object interface{}, key string) *gvar.Var

使用示例

Data方法

Data方法用于获取指定struct对象的元数据标签,构成map返回。

  1. package main
  2. import (
  3. "fmt"
  4. "github.com/gogf/gf/frame/g"
  5. "github.com/gogf/gf/util/gmeta"
  6. )
  7. func main() {
  8. type User struct {
  9. gmeta.Meta `orm:"user" db:"mysql"`
  10. Id int
  11. Name string
  12. }
  13. g.Dump(gmeta.Data(User{}))
  14. }

执行后,终端输出:

  1. {
  2. "db": "mysql",
  3. "orm": "user"
  4. }

Get方法

Get方法用于获取指定struct对象中指定名称的元数据标签信息。

  1. package main
  2. import (
  3. "fmt"
  4. "github.com/gogf/gf/util/gmeta"
  5. )
  6. func main() {
  7. type User struct {
  8. gmeta.Meta `orm:"user" db:"mysql"`
  9. Id int
  10. Name string
  11. }
  12. user := User{}
  13. fmt.Println(gmeta.Get(user, "orm").String())
  14. fmt.Println(gmeta.Get(user, "db").String())
  15. }

执行后,终端输出:

  1. user
  2. mysql

Content Menu