Beego脱坑(七)——多种格式数据输出

  • 直接输出

直接输出我们前面一直在用,通过beego.Controller.Ctx.WriteString()方法可以直接向http response body中输出字符串。

例如:

this.Ctx.WriteString("hello world")
  • 模板输出

静态模板输出

静态模板输出,就是通过TplName指定简单的模板文件,讲html或者tpl文件直接输出到浏览器

静态模板:


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>Hello World!</h1>
</body>
</html>
路由注册:
beego.Router("/hello",&controllers.HWControllers{})

控制器代码:

package controllers
 
import "github.com/astaxie/beego"
 
type HWControllers struct {
	beego.Controller
}
 
func (this *HWControllers) Get() {
	this.TplName ="hello.html"
}
 

输出结果:
在这里插入图片描述

动态模板输出

在web中大部分的内容是静态的,只有少部分数据是动态的。为了复用模板的代码,需要能够把动态的数据插入到模板中,这需要特出的语法。

beego中模板通过{{}}包含需要被替换的字段,同时需要把要替换的内容添加到Controller的Data中,这样Controller执行时会自动匹配渲染模板。

静态模板:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>你猜我会输出什么:{{.HW}}</h1>
</body>
</html>

路由注册:

 beego.Router("/hello",&controllers.HWControllers{})

控制器代码:

package controllers
 
import "github.com/astaxie/beego"
 
type HWControllers struct {
	beego.Controller
}
 
func (this *HWControllers) Get() {
	this.Data["HW"] ="Hello  World"
	this.TplName ="hello.html"
}

我们只是简单的修改了下上面的代码。现在来看看输出结果:
在这里插入图片描述

beego 当初设计的时候就考虑了 API 功能的设计,而我们在设计 API 的时候经常是输出 JSON 或者 XML 数据,那么 beego 提供了这样的方式直接输出:

特别注意的一个坑点,如果是想要把结构体作为输出对象,以属性名一定要大写。因为go的首字母大写代表为pubic属性。

我们先定义User一个结构体,为下面两种输出方式使用

  • json格式数据输出
func (this *ApiController) Get(){
	user:= &User{"yj",20,"m"}
	this.Data["json"] =user  
	this.ServeJSON()
}

调用 ServeJSON 之后,会设置 content-type 为 application/json,然后同时把数据进行 JSON 序列化输出。

输出结果:

在这里插入图片描述

  • XML格式数据输出
func (this *ApiController) XmlFunc(){
 
	user:= &User{"yj",20,"m"}
	this.Data["xml"] =user
	this.ServeXML()
}

调用 ServeXML 之后,会设置 content-type 为 application/xml,同时数据会进行 XML 序列化输出。

输出结果:
在这里插入图片描述


作者:Clown95
来源:CSDN
原文:https://blog.csdn.net/yang731227/article/details/82287084
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值