用 net/http 足够开发 TODO 应用,无需过早引入 Gin/Echo;SQLite 关 WAL 模式避免 locked 错误;纯 HTML + fetch 实现 CRUD,统一加 CORS 头并处理 OPTIONS 预检。用 net/http 启服务就足够,别一上来搞 Gin/echoGo 写 TODO 应用,最常踩的坑是过早引入 Web 框架。你只是想存几条待办、查一下、删一条------net/http 加 encoding/json 完全够用,启动快、依赖少、调试直观。真实场景里,90% 的本地开发或小工具级 TODO 应用根本不需要中间件链、路由分组、上下文注入这些。用框架反而让你绕不开它的生命周期钩子、错误包装逻辑,一报错先怀疑是不是自己没配对 router.Use()。HTTP 方法直接对应 CRUD:GET /todos 查列表,POST /todos 新增,DELETE /todos/{id} 删除用 http.ServeMux 就能注册路由,不用 http.HandleFunc 也能写清楚路径和 handler 分离避免用 json.RawMessage 或自定义 UnmarshalJSON------除非你要支持嵌套字段或时间格式混用,否则标准结构体 + json:"text,omitempty" 更稳sqlite3 做存储比内存 map 更靠谱,但得关掉 WAL 模式很多人用 mapint*Todo 开发初期觉得"简单",结果加个刷新页面就丢数据,或者并发 POST 两条导致 ID 冲突。SQLite 是零配置、单文件、ACID 兼容的真退路。但默认开启的 WAL(Write-Ahead Logging)模式在 Go 的 database/sql 连接池下容易卡住:多个 goroutine 同时写,sqlite3 报 database is locked,不是代码问题,是模式不匹配。立即学习"go语言免费学习笔记(深入)";初始化 DB 时加 _journal_mode=DELETE&_synchronous=NORMAL 参数,关 WAL,用传统 rollback journal表结构别省事:id INTEGER PRIMARY KEY AUTOINCREMENT 而不是 id INTEGER PRIMARY KEY,否则 SQLite 不保证自增连续性查询全部用 SELECT * FROM todos ORDER BY id DESC,别依赖 INSERT 顺序------SQLite 不保证返回顺序,除非显式 ORDER BY前端用纯 HTML + fetch 就行,别碰 Vue/ReactTODO 应用的 UI 复杂度在「输入框 + 列表 + 删除按钮」这个量级。这时候上构建工具、打包、热更新,等于给自行车装涡轮增压------噪音大,还容易爆缸。 Cleanup.pictures 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西
相关推荐
曲幽1 小时前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API渣波1 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码荣码1 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面兵慌码乱11 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析金銀銅鐵12 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程FreakStudio16 小时前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发用户03321266636717 小时前
使用 Python 从零创建 Word 文档Csvn1 天前
Python 两大经典坑点 —— 可变默认参数 & 闭包延迟绑定曲幽1 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了用户556918817531 天前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录