在看别人的一些代码时,声明结构时有个是做什么用的?
想知道原因得了解下:
在golang中,命名都是推荐都是用驼峰方式,并且在首字母大小写有特殊的语法含义:包外无法引用。但是由经常需要和其它的系统进行数据交互,例如转成json格式,存储到Redis等等。这个时候如果直接用属性名来作为键值会不符合项目要求。
于是就有了tag,也就是有了或者也或者json:name orm:"size(1000)"这样的声明。
在我们把结构转成json时 就会以tag里面的名字出现。
下面这是我在用beego框架的orm声明的一个结构体
当我们在控制器中写api时就可以直接取了
这时访问接口返回的数据就是以tag里面的命名的key
作者:满损谦益链接:http://www.jianshu.com/p/7bd3adc99efe來源:简书著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。json:namejson:nameorm:"size(1000)"// 评论
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"`
}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
}