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、做迁移才不会一地鸡毛。

相关推荐
用户83562907805116 小时前
无需 Office:Python 批量转换 PPT 为图片
后端·python
markfeng817 小时前
Python+Django+H5+MySQL项目搭建
python·django
GinoWi18 小时前
Chapter 2 - Python中的变量和简单的数据类型
python
JordanHaidee18 小时前
Python 中 `if x:` 到底在判断什么?
后端·python
ServBay18 小时前
10分钟彻底终结冗长代码,Python f-string 让你重获编程自由
后端·python
闲云一鹤19 小时前
Python 入门(二)- 使用 FastAPI 快速生成后端 API 接口
python·fastapi
Rockbean20 小时前
用40行代码搭建自己的无服务器OCR
服务器·python·deepseek
曲幽20 小时前
FastAPI + Ollama 实战:搭一个能查天气的AI助手
python·ai·lora·torch·fastapi·web·model·ollama·weatherapi
用户606487671889621 小时前
国内开发者如何接入 Claude API?中转站方案实战指南(Python/Node.js 完整示例)
人工智能·python·api
只与明月听1 天前
RAG深入学习之Chunk
前端·人工智能·python