golang API json,struct结构中标签(Tag)的使用

前端之家收集整理的这篇文章主要介绍了golang API json,struct结构中标签(Tag)的使用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
 
 

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

想知道原因得了解下:

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

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

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

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


  
  

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


  
  

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


返回的json
作者:满损谦益链接: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 }

猜你在找的Go相关文章