字段标签允许您将元信息附加到可以使用反射获取的字段上。通常,它用于提供有关如何将结构域编码为另一种格式(或从另一种格式存储(或从数据库中检索))的转换信息,但是您可以使用它存储想要存储的任何元信息,这些元信息既可以用于另一种包装或供您自己使用。
如的文档所述
reflect.StructTag,按照惯例,标记字符串的值是用空格分隔的
key:"value"成对列表,例如:
type User struct { Name string `json:"name" xml:"name"`}的
key通常表示包,随后的
"value"是,例如
json密钥被处理/使用的
encoding/json包。
如果要在中传递多个信息
"value",通常通过用逗号(
',')隔开来指定它,例如
Name string `json:"name,omitempty" xml:"name"`
通常用破折号(
'-')
"value"表示将字段从过程中排除(例如,在这种情况下,
json表示不封送或取消封送该字段)。
使用反射访问自定义标签的示例
我们可以使用反射(
reflect包)来访问结构字段的标记值。基本上,我们需要获取
Type结构的,然后可以使用
Type.Field(iint)或查询字段
Type.FieldByName(namestring)。这些方法返回的值
StructField描述/表示一个struct字段;并且
StructField.Tag是
StructTag描述/表示标记值的类型值。
以前我们谈论过 “惯例” 。该公约的手段,如果你遵循它,你可以使用
StructTag.Get(keystring)它解析变量的值,并返回该方法
"value"的
key指定。该
公约
实施/内置到这个
Get()方法。如果您不遵守约定,
Get()将无法解析
key:"value"对并找到您要查找的内容。这也不是问题,但是随后您需要实现自己的解析逻辑。
还有
StructTag.Lookup()(在Go
1.7中添加了),它 “类似于,
Get()但是将不包含给定键的标签与将空字符串与给定键相关联的标签区分开”。
因此,让我们看一个简单的示例:
type User struct { Name string `mytag:"MyName"` Email string `mytag:"MyEmail"`}u := User{"Bob", "bob@mycompany.com"}t := reflect.TypeOf(u)for _, fieldName := range []string{"Name", "Email"} { field, found := t.FieldByName(fieldName) if !found { continue } fmt.Printf("nField: User.%sn", fieldName) fmt.Printf("tWhole tag value : %qn", field.Tag) fmt.Printf("tValue of 'mytag': %qn", field.Tag.Get("mytag"))}输出(在Go Playground上尝试):
Field: User.Name Whole tag value : "mytag:"MyName"" Value of 'mytag': "MyName"Field: User.Email Whole tag value : "mytag:"MyEmail"" Value of 'mytag': "MyEmail"
GopherCon 2015上有一个关于struct标签的演示,名为:
结构标签的许多面孔(幻灯片)
(和视频)
以下是常用标签键的列表:
json
-由encoding/json
包装使用,详细说明json.Marshal()
xml
-由encoding/xml
包装使用,详细说明xml.Marshal()
bson
-由gobson使用,详细说明bson.Marshal()
protobuf
-由github.com/golang/protobuf/proto
,在软件包doc中有详细说明yaml
-由gopkg.in/yaml.v2
包装使用,详细说明yaml.Marshal()
db
-由github.com/jmoiron/sqlx
包装使用;也被github.com/go-gorp/gorp
包装使用orm
-由github.com/astaxie/beego/orm
包装使用,在“ 型号– Beego ORM”中有详细说明gorm
-由github.com/jinzhu/gorm
软件包使用,示例可在其文档中找到:模型valid
-由github.com/asaskevich/govalidator
软件包使用,示例可以在项目页面中找到datastore
-由appengine/datastore
(Google App Engine平台,数据存储区服务)使用,在“ 属性”中有详细说明schema
-用于通过HTML表单值github.com/gorilla/schema
填充(struct
包文档中有详细说明)asn
-由encoding/asn1
包装使用,详细说明在asn1.Marshal()
和asn1.Unmarshal()
csv
-由github.com/gocarina/gocsv
包装使用



