在看别人的一些代码时,声明结构时有个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