一、安装、新建项目
首先需要安装 beego 环境,安装 bee 脚手架等。具体可以参考我的这篇文章:Go 安装教程。
然后在文件夹下新建一个 beego 项目:
bee new beegodemo
然后,需要进入 beegodemo 文件夹下,如果没有 go mod
文件,需要 init
一下:
go mod init
此时 beegodemo 文件夹下应该有这些文件:
二、控制器、路由
使用 Goland 打开 beegodemo 文件夹,可以看到这个项目:
controllers 文件夹下有一个默认文件 default.go,新建一个 goods.go 文件,输入下面代码:
package controllers
import (
"github.com/astaxie/beego"
)
type GoodsController struct { // 首字母要大写
beego.Controller
}
func (c *GoodsController) Get() {
c.Data["title"] = "你好beego" // 绑定数据
c.TplName = "goods.tpl"
}
然后需要在 routers 文件夹下的 router.go 中添加路由:
package routers
import (
"beegodemo/controllers"
"github.com/astaxie/beego"
)
func init() {
beego.Router("/", &controllers.MainController{})
beego.Router("/goods", &controllers.GoodsController{}) // 结构体地址
}
再在 views 文件夹下增加一个 goods.tpl 文件,输入以下代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Beego</title>
</head>
<body>
<h3>这是一个商品模块</h3>
<br>
<p>{{.title}}</p>
</body>
</html>
此时配置 Goland 右上角运行项目的配置,参考我之前写的文章,主要就是这一栏需要定位到 main.go 文件:
然后点击运行,就可以看到 Terminal 里呈现以下情况:
然后打开浏览器,输入 http://localhost:8080/goods
,可以看到:
同样新建一个 article.go 文件,输入以下代码:
package controllers
import (
"github.com/astaxie/beego"
)
type ArticleController struct { // 首字母要大写
beego.Controller
}
func (c *ArticleController) Get() {
c.Ctx.WriteString("新闻列表") // 直接给页面返回数据
}
func (c *ArticleController) AddArticle() {
c.Ctx.WriteString("增加新闻")
}
func (c *ArticleController) EditArticle() {
c.Ctx.WriteString("修改新闻")
}
然后在 router.go 中增加路由:
package routers
import (
"beegodemo/controllers"
"github.com/astaxie/beego"
)
func init() {
beego.Router("/", &controllers.MainController{})
beego.Router("/goods", &controllers.GoodsController{}) // 结构体地址
beego.Router("/article", &controllers.ArticleController{}) // 访问 Get 方法
beego.Router("/article/add", &controllers.ArticleController{}, "get:AddArticle") // 访问自定义方法
beego.Router("/article/edit", &controllers.ArticleController{}, "get:EditArticle") // 结构体地址
}
运行项目,打开浏览器,输入 http://localhost:8080/article/add
,可以看到:
同样,http://localhost:8080/article/edit
也是如此。