在看别人的一些代码时,声明结构时有个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
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦