golang结构体tag是如何使用

🧠 一、什么是结构体 Tag?

在 Go 中,结构体字段可以有额外的元信息,称为 Tag(标签)。这些信息通常用于:

  • 序列化(如 json, xml, yaml

  • 表单绑定(如 form)

  • 校验(如 validate)

  • 数据库映射(如 gorm, xorm

Tag 写在结构体字段名的后面,用 反引号 ``` 包裹。


🧱 二、结构体 Tag 的基本语法

type StructName struct {
    FieldName FieldType `tagKey:"tagValue"`
}

💡 多个 tag空格隔开,例如:

FieldName string `json:"name" xml:"name" validate:"required"`

🧩 三、图示讲解结构体 tag 组成

type User struct {
    ID    int    `json:"id"`
    Name  string `json:"name"`
    Email string `json:"email,omitempty"`
    Age   int    `json:"-"`             // 不序列化
}
字段名类型Tag 字符串含义
IDintjson:"id"JSON 输出为 id
Namestringjson:"name"JSON 输出为 name
Emailstringjson:"email,omitempty"如果为零值则不输出
Ageintjson:"-"永远忽略,不输出

📦 四、实战场景演示

✅ 示例1:JSON 序列化

package main
​
import (
    "encoding/json"
    "fmt"
)
​
type User struct {
    ID    int    `json:"id"`
    Name  string `json:"name"`
    Email string `json:"email,omitempty"`
    Age   int    `json:"-"`
}
​
func main() {
    user := User{ID: 1001, Name: "李雷", Email: "", Age: 30}
    result, _ := json.Marshal(user)
    fmt.Println(string(result)) // 输出:{"id":1001,"name":"李雷"}
}

🔍 为什么只有 ID 和 Name?

  • Email 为空,使用了 omitempty

  • Age 被忽略,使用了 "-"


✅ 示例2:GORM 中的数据库映射 tag

type Product struct {
    ID    int    `gorm:"primaryKey;autoIncrement" json:"id"`
    Name  string `gorm:"type:varchar(100);not null" json:"name"`
    Price int    `gorm:"column:product_price" json:"price"`
}
tag 类型示例内容说明
gormprimaryKey, type, column表示数据库字段特性
jsonjson:"name"表示 JSON 序列化字段名

✅ 示例3:表单解析 + 校验 tag

type LoginForm struct {
    Username string `form:"username" json:"username" binding:"required"`
    Password string `form:"password" json:"password" binding:"required,min=6"`
}
tag用法
form表单字段绑定,例如 HTTP POST 请求
jsonJSON 请求体解析
binding验证字段,如 required, min=6

🧪 五、如何读取 Tag?

通过反射(reflect)读取结构体字段的 tag。

import (
    "fmt"
    "reflect"
)
​
type Person struct {
    Name string `json:"name" label:"姓名"`
}
​
func main() {
    t := reflect.TypeOf(Person{})
    field := t.Field(0)
​
    fmt.Println("json tag:", field.Tag.Get("json"))  // 输出 name
    fmt.Println("label tag:", field.Tag.Get("label"))// 输出 姓名
}

🧠 六、tag 使用建议

建议原因
❗避免乱写tag 格式要正确,例如反引号必须成对
✅ 多 tag 用空格分隔保持清晰易读
🧪 可以结合反射动态读取 tag做校验、自动映射等功能
🔐 不要暴露敏感字段到 JSON 中使用 json:"-"

🎁 七、可视化图(结构体 tag 工作流程)

+-------------------+
| struct 定义       |
|-------------------|
| Name string       |
|      `json:"name"`| ----->  序列化 JSON 输出字段 "name"
+-------------------+

👉 立即点击链接,开启你的全栈开发之路:Golang全栈开发完整课程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值