108 lines
3.2 KiB
Markdown
108 lines
3.2 KiB
Markdown
# 612 班级纪念站
|
||
|
||
这是一个用 Astro 搭建的班级纪念网站,用来保存毕业后的班级记忆:时间线、照片墙、同学近况、综合试卷和留言墙。
|
||
|
||
## 功能
|
||
|
||
- 首页:班级纪念入口、导航和基础统计。
|
||
- 三年时间线:记录高中阶段的重要片段。
|
||
- 照片墙:按专题整理课堂日常、班级活动、毕业当天和随手抓拍。
|
||
- 如今的我们:展示同学卡片和个人近况页面。
|
||
- 综合试卷:把纪念试卷做成网页,并保留 Word 原卷下载。
|
||
- 留言墙:接入 Twikoo 后可在页面中留言。
|
||
|
||
## 技术栈
|
||
|
||
- Astro 6
|
||
- TypeScript
|
||
- 原生 CSS
|
||
- Twikoo 评论系统
|
||
|
||
## 快速开始
|
||
|
||
```bash
|
||
npm install
|
||
npm run dev
|
||
```
|
||
|
||
本地开发服务启动后,按终端提示打开页面即可。
|
||
|
||
常用命令:
|
||
|
||
```bash
|
||
npm run dev # 启动开发服务器
|
||
npm run build # 构建静态站点到 dist
|
||
npm run preview # 预览构建结果
|
||
```
|
||
|
||
## 项目结构
|
||
|
||
```text
|
||
.
|
||
|-- public/
|
||
| `-- assets/ # 静态图片、试卷附件等资源
|
||
|-- scripts/ # GitHub Issue 自动更新数据脚本
|
||
|-- src/
|
||
| |-- data/ # 站点内容数据
|
||
| | |-- site.ts # 站点标题、导航、联系方式
|
||
| | |-- timeline.ts # 时间线内容
|
||
| | |-- photos.ts # 照片墙入口数据
|
||
| | |-- photo-topics/ # 各照片专题
|
||
| | |-- people.ts # 同学资料
|
||
| | |-- exam.ts # 综合试卷内容与评分配置
|
||
| | `-- messages.ts # 留言墙文案与 Twikoo 配置
|
||
| |-- layouts/ # 通用页面布局
|
||
| |-- pages/ # 路由页面
|
||
| `-- styles/ # 全局和页面样式
|
||
|-- astro.config.mjs
|
||
`-- package.json
|
||
```
|
||
|
||
## 内容维护
|
||
|
||
大部分网站内容都在 `src/data` 目录中维护。
|
||
|
||
- 修改站点名称、首页文案、导航和联系方式:编辑 `src/data/site.ts`
|
||
- 修改时间线:编辑 `src/data/timeline.ts`
|
||
- 修改照片墙专题:编辑 `src/data/photo-topics/*.ts`
|
||
- 修改同学资料:编辑 `src/data/people.ts`
|
||
- 修改试卷内容和答案:编辑 `src/data/exam.ts`
|
||
- 修改留言墙文案和 Twikoo 配置:编辑 `src/data/messages.ts`
|
||
|
||
新增静态资源时,放到 `public/assets` 下。页面中引用资源时使用以 `/assets/` 开头的路径,例如:
|
||
|
||
```ts
|
||
photo: "/assets/photos/example.jpg"
|
||
```
|
||
|
||
## 留言墙配置
|
||
|
||
留言墙使用 Twikoo。需要在本地或部署平台中配置环境变量:
|
||
|
||
```bash
|
||
PUBLIC_TWIKOO_ENV_ID=你的_Twikoo_envId
|
||
```
|
||
|
||
如果没有配置该变量,留言页会显示待配置提示,不会加载评论区。
|
||
|
||
## GitHub Issue 自动更新
|
||
|
||
仓库中包含用于收集内容更新的 Issue 模板和 GitHub Actions:
|
||
|
||
- `people-update`:根据 Issue 表单更新 `src/data/people.ts`
|
||
- `photo-update`:根据 Issue 表单更新对应的照片专题数据
|
||
|
||
提交或编辑对应 Issue 后,工作流会运行脚本并自动创建更新 PR,方便审核后合并。
|
||
|
||
## 构建与部署
|
||
|
||
执行:
|
||
|
||
```bash
|
||
npm run build
|
||
```
|
||
|
||
构建产物会生成到 `dist/`。这个项目是静态站点,可以部署到 GitHub Pages、Vercel、Netlify 或任意静态资源服务器。
|
||
|
||
部署前建议检查 `astro.config.mjs` 中的 `site` 字段,把它改成真实站点地址。
|