Golang实战开发ToDo应用教程
时间:2026-02-21 22:47:40 199浏览 收藏
本文手把手带你用 Golang 从零打造一个功能完整的 ToDo 待办应用,涵盖项目结构设计、Task 模型定义、内存模拟数据库、HTTP 路由与增删改查处理器开发,以及 HTML 模板动态渲染等核心 Web 开发环节,既夯实了 Go 语言的实战能力,又打通了前后端交互的关键链路——简洁清晰、即学即用,是入门 Go Web 开发不可多得的落地范例,后续还可轻松扩展为支持持久化、API 接口和用户认证的生产级应用。

用 Golang 构建一个 ToDo 待办事项应用是入门 Web 开发的绝佳方式。它涵盖了路由、HTTP 处理、数据存储和基本前后端交互等核心概念。下面是一个简洁实用的实战指南,带你从零开始搭建一个基础但完整的 ToDo 应用。
项目结构设计
合理的项目结构有助于后续维护和扩展。建议采用如下目录结构:
- main.go – 程序入口,启动 HTTP 服务
- handlers/ – 存放 HTTP 请求处理函数
- models/ – 定义数据结构(如 Task)和操作逻辑
- storage/ – 数据持久化层(这里先用内存模拟)
- templates/ – HTML 模板文件
定义任务模型与存储
在 models/task.go 中定义任务结构体:
type Task struct {
ID int `json:"id"`
Title string `json:"title"`
Done bool `json:"done"`
}
在 storage/memory.go 中使用 map 模拟数据库:
var tasks = make(map[int]Task)
var nextID = 1
func GetAllTasks() []Task {
var result []Task
for _, t := range tasks {
result = append(result, t)
}
return result
}
func AddTask(task Task) Task {
task.ID = nextID
nextID++
tasks[task.ID] = task
return task
}
func UpdateTask(id int, updated Task) (Task, bool) {
if t, exists := tasks[id]; exists {
updated.ID = id
tasks[id] = updated
return updated, true
}
return Task{}, false
}
func DeleteTask(id int) bool {
_, exists := tasks[id]
if exists {
delete(tasks, id)
}
return exists
}
编写 HTTP 路由与处理器
在 handlers/task_handler.go 中实现增删改查接口:
func GetTasks(w http.ResponseWriter, r *http.Request) {
tasks := storage.GetAllTasks()
t, _ := template.ParseFiles("templates/index.html")
t.Execute(w, tasks)
}
func CreateTask(w http.ResponseWriter, r *http.Request) {
if r.Method == "POST" {
title := r.FormValue("title")
task := models.Task{Title: title, Done: false}
storage.AddTask(task)
}
http.Redirect(w, r, "/", http.StatusSeeOther)
}
在 main.go 中注册路由:
func main() {
http.HandleFunc("/", handlers.GetTasks)
http.HandleFunc("/add", handlers.CreateTask)
http.HandleFunc("/toggle", handlers.ToggleTask)
http.HandleFunc("/delete", handlers.DeleteTask)
fmt.Println("Server starting on :8080")
http.ListenAndServe(":8080", nil)
}
前端页面展示(HTML 模板)
在 templates/index.html 中使用 Go 模板语法渲染任务列表:
<h1>ToDo List</h1>
<form method="post" action="/add">
<input type="text" name="title" placeholder="Add new task" required>
<button type="submit">Add</button>
</form>
<ul>
{{range .}}
<li style="text-decoration:{{if .Done}}line-through{{end}}">
{{.Title}}
<a href="/toggle?id={{.ID}}">Toggle</a>
<a href="/delete?id={{.ID}}">Delete</a>
</li>
{{end}}
</ul>
这个模板接收任务切片作为数据,动态生成 HTML 列表,并提供切换状态和删除功能。
基本上就这些。通过这个小项目,你掌握了 Golang Web 开发的基本流程:定义数据模型、实现业务逻辑、处理 HTTP 请求、连接前端展示。后续可以逐步加入 JSON API 支持、SQLite 存储、CSS 样式优化,甚至加上用户认证。不复杂但容易忽略的是错误处理和请求校验,实际项目中要补全。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Golang实战开发ToDo应用教程》文章吧,也可关注golang学习网公众号了解相关技术文章。
相关阅读
更多>
-
505 收藏
-
503 收藏
-
502 收藏
-
502 收藏
-
502 收藏
最新阅读
更多>
-
371 收藏
-
374 收藏
-
212 收藏
-
189 收藏
-
185 收藏
-
297 收藏
-
133 收藏
-
445 收藏
-
426 收藏
-
144 收藏
-
389 收藏
-
331 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习