Alicea Wind的个人网站开发日志(2)

第二天的工作,重点已经不在"页面长什么样",而是开始思考:这个网站靠什么活起来

第一天我把首页结构和视觉大致定下来之后,很快就意识到一个问题------如果所有内容都只是写死在前端,那这个网站本质上还是一张"展示图",而不是一个正在运转的系统。哪怕是个人站,也应该有最基本的数据流动。

于是第二天的目标变得很明确:引入后端,让页面开始从接口拿数据


从"项目卡片"开始,而不是从登录开始

我没有一上来就做用户系统、鉴权、数据库那一套。原因很简单:那会让我在"还没决定站点内容形态"的情况下,先陷入技术细节。

相比之下,"项目列表"是一个非常自然的切入点:

  • 首页已经有"项目"这个板块

  • 项目本身就是这个站点的核心内容

  • 即使没有数据库,也可以先用静态数据模拟

于是我决定:先给项目列表一个真实的 API


用 FastAPI 搭一个"足够真实"的最小后端

后端我用的是 FastAPI。并不是为了炫什么技术,而是它非常适合这种"从 0 到 1"的阶段:结构清晰、反馈快、接口即文档。

这一天我在后端里做了三件事:

  • 一个健康检查接口,用来确认服务是否在线

  • 一个简单的访问计数接口,用来验证前后端通信

  • 一个真正用于业务的 /api/projects 接口

项目列表暂时还只是内存中的静态数据,但字段已经按"将来会进数据库"的标准来设计,包括 idtitlesummarytagsstatus 等。接口也支持按标签和状态筛选,这样前端逻辑就可以提前写好,后面换数据源时不用动页面结构。

后端的整体结构非常克制,没有引入多余的东西,只保证一件事:前端可以稳定地拿到它需要的数据

main


前端第一次"真正依赖后端"

当我把项目区块从"写死的卡片"改成"从接口拉数据"时,页面的性质发生了变化。

项目列表现在具备了几个特征:

  • 页面刷新会重新请求数据

  • 标签筛选基于接口返回的 tags 自动生成

  • 出错时会有明确的错误提示

  • 没有数据时有空状态兜底

这些都不是复杂功能,但它们让这个页面不再只是一个 UI,而是一个可以承受变化的模块。

有一个小插曲是,我在前端第一次请求接口时,报了 API_BASE is not defined。这并不是什么大问题,但它提醒我:项目已经走到需要"配置层"的阶段了,接口地址、环境区分这些概念已经开始出现。这其实是一个好信号。


开始正视"数据库这件事"

当接口跑通、页面也能正常展示项目后,一个问题变得无法回避:这些数据总不能永远放在内存里。

于是第二天的后半段,我开始着手数据库相关的事情,包括:

  • 用 DBeaver 连接 MySQL

  • 区分本地数据库和服务器数据库

  • 明确 MySQL 是通过 Docker 跑的服务,而不是一个"点开就能用的应用"

  • 用命令行确认 MySQL 是否真的在运行

这些步骤看起来很基础,但它们是后端工程的地基。只有在这一步不含糊,后面建表、写 ORM、做迁移才不会一地鸡毛。

相关推荐
金銀銅鐵15 小时前
[Python] 基于欧几里得算法,实现分数约分计算器
python·数学
Lyn_Li17 小时前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现
python·kaggle·比赛复盘·金融预测
小九九的爸爸21 小时前
前端想要入门Agent开发,要具备哪些Python基础?
python·agent·ai编程
阿耶同学1 天前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构
python·程序员
花酒锄作田2 天前
Pydantic校验配置文件
python
hboot2 天前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
ZhengEnCi2 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi2 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽2 天前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
用户8358086187912 天前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python