Beego 框架学习笔记 01 | 创建 Beego 项目

Wonz · · 899 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

一、安装、新建项目

首先需要安装 beego 环境,安装 bee 脚手架等。具体可以参考我的这篇文章:Go 安装教程

然后在文件夹下新建一个 beego 项目:

bee new beegodemo

然后,需要进入 beegodemo 文件夹下,如果没有 go mod 文件,需要 init 一下:

go mod init
image

此时 beegodemo 文件夹下应该有这些文件:

image

二、控制器、路由

使用 Goland 打开 beegodemo 文件夹,可以看到这个项目:

image

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 文件:

image

然后点击运行,就可以看到 Terminal 里呈现以下情况:

image

然后打开浏览器,输入 http://localhost:8080/goods,可以看到:

image

同样新建一个 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,可以看到:

image

同样,http://localhost:8080/article/edit 也是如此。

三、参考教程

Golang 教程 P51-P52


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:Wonz

查看原文:Beego 框架学习笔记 01 | 创建 Beego 项目

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

899 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传