在看别人的一些代码时,声明结构时有个json:name是做什么用的?

想知道原因得了解下:

在golang中,命名都是推荐都是用驼峰方式,并且在首字母大小写有特殊的语法含义:包外无法引用。但是由经常需要和其它的系统进行数据交互,例如转成json格式,存储到Redis等等。这个时候如果直接用属性名来作为键值会不符合项目要求。

于是就有了tag,也就是有了json:name或者orm:"size(1000)"也或者json:name orm:”size(1000)”这样的声明。

在我们把结构转成json时 就会以tag里面的名字出现。

下面这是我在用beego框架的orm声明的一个结构体

// 评论
type Comment struct {
    Id       int64     `json:"id"`
    Tid      int64     `json:"tid"`
    NickName string    `json:"nickName"`
    Content  string    `json:"content" orm:"size(1000)"`
    Created  time.Time `json:"created" orm:"index"`
}

当我们在控制器中写api时就可以直接取了

func (this *ApiCommentController) All() {

    tid := this.Input().Get("tid")
    // 获取评论
    comments, err := models.GetAllComment(tid)
    if err != nil {
        beego.Error(err)
    }

    this.Data["json"] = map[string]interface{}{
        "code":    0,
        "message": "获取成功",
        "date":    comments,
    }
    this.ServeJSON()
    return

}

这时访问接口返回的数据就是以tag里面的命名的key

返回的json

[获取授权]

文章来源于互联网:golang API json,struct结构中标签(Tag)的使用

发表评论