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

相关推荐
hedley(●'◡'●)11 小时前
基于cesium和vue的大疆司空模仿程序
前端·javascript·vue.js·python·typescript·无人机
我找到地球的支点啦11 小时前
通信扩展——扩频技术(超级详细,附带Matlab代码)
开发语言·matlab
啊阿狸不会拉杆11 小时前
《机器学习导论》第 5 章-多元方法
人工智能·python·算法·机器学习·numpy·matplotlib·多元方法
wangsir.12 小时前
测试之自动化测试常用函数
python·测试
微小冷12 小时前
Rust异步编程详解
开发语言·rust·async·await·异步编程·tokio
铁蛋AI编程实战12 小时前
MemoryLake 实战:构建超长对话 AI 助手的完整代码教程
人工智能·python·microsoft·机器学习
A9better12 小时前
C++——不一样的I/O工具与名称空间
开发语言·c++·学习
清水白石00812 小时前
《为什么说 deque 是 Python 滑动窗口的“隐藏神器”?深入解析双端队列的高效之道》
开发语言·python
杜子不疼.12 小时前
Ascend_C自定义算子开发
c语言·开发语言