Golang实现简易投票网站教程
时间:2026-01-21 16:15:48 429浏览 收藏
各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题是《Golang开发简易投票网站教程》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!
用Go标准库实现简易投票网站:前端HTML表单以POST提交单选选项,后端用sync.Map内存计数并重定向,/路径动态渲染统计结果与表单,支持实时查看票数变化。

用 Go 开发一个简易投票网站,核心在于:前端表单提交选项,后端接收并持久化计数,再实时展示统计结果。不需要复杂框架,标准库 net/http 和少量 HTML 即可实现。
前端:简洁表单 + 选项提交
写一个静态 HTML 页面(如 index.html),包含投票选项和提交按钮。关键点是使用 POST 方法提交,每个选项用 name="choice" 的单选按钮(radio):
<form method="POST" action="/vote"> <label><input type="radio" name="choice" value="go"> Go</label><br> <label><input type="radio" name="choice" value="rust"> Rust</label><br> <label><input type="radio" name="choice" value="python"> Python</label><br> <button type="submit">投票</button> </form>
注意:action="/vote" 指向后端处理路径;所有选项共享同一个 name,确保单选互斥。
后台:接收、计数、存储(内存版)
Go 后端用 http.HandleFunc 处理两个路由:/ 返回页面,/vote 接收表单数据。用 sync.Map 安全地在内存中累计票数(适合演示,生产环境应换数据库):
- 定义全局
var votes = sync.Map{}存储各选项的票数(key=string, value=int64) - 在
/vote处理器中调用r.ParseForm(),再用r.FormValue("choice")获取选中的值 - 用
votes.LoadOrStore(choice, int64(0))初始化,再用atomic.AddInt64增加票数(需先断言为*int64或改用封装结构) - 处理完重定向回
/,避免重复提交
统计展示:动态渲染结果
在 / 的处理器中,遍历 votes 读取所有选项及票数,拼接 HTML 字符串返回(或用 html/template 更清晰):
- 先收集所有选项:可以预设选项列表(
[]string{"go", "rust", "python"}),避免漏显 - 对每个选项,调用
votes.Load(option)获取当前票数,转成整数 - 在 HTML 中以列表或进度条形式展示,例如:Go: 12 票
- 把原始表单也嵌入同一页面,实现“投完即见结果”
运行与验证
启动服务:go run main.go,浏览器访问 http://localhost:8080 即可投票。刷新页面查看统计变化。若需持久化,后续可替换 sync.Map 为 JSON 文件读写,或接入 SQLite。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。
-
505 收藏
-
503 收藏
-
502 收藏
-
502 收藏
-
502 收藏
-
129 收藏
-
456 收藏
-
358 收藏
-
438 收藏
-
313 收藏
-
268 收藏
-
273 收藏
-
401 收藏
-
144 收藏
-
104 收藏
-
428 收藏
-
469 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习