- 首页判定:navigation 第一项 - 模板:page/projects/articles/bookmarks/search-results - bookmarks:update: YYYY-MM-DD | from: git|mtime - articles:RSS 聚合只读条目 + 分类聚合 + 影子写回结构 - projects:repo 卡片 + 可选热力图 + 自动抓取元信息 - 工作流:构建前 sync + schedule 定时刷新 - 移除兼容:config.yml/config.yaml、navigation.yml、home 特例 - 迁移说明:config/update-instructions.md
2.7 KiB
2.7 KiB
更新说明(兼容性移除 / 迁移指南)
本文档说明本次“页面模板差异化改进”阶段,在配置/构建链路上移除的历史兼容行为以及如何迁移。
最后更新:2025-12-27
1. 已移除的兼容行为(Breaking)
1.1 不再支持旧版单文件配置 config.yml / config.yaml
- 旧版本在未发现
config/user/与config/_default/时,会回退读取根目录的config.yml/config.yaml。 - 当前版本:仅支持模块化配置目录:
config/user/(优先级最高,完全替换)config/_default/(默认示例)
迁移要点:
- 如果你只有
config.yml/config.yaml:请将其内容拆分到config/user/site.yml与config/user/pages/*.yml。 - 推荐做法:先复制一份默认示例,再按需替换字段:
- 复制
config/_default/→config/user/ - 修改
config/user/site.yml、config/user/pages/*.yml
- 复制
1.2 不再支持独立 navigation.yml
- 旧版本可能存在
config/user/navigation.yml(或_default/navigation.yml)作为导航配置来源。 - 当前版本:导航仅从
site.yml -> navigation读取;不再回退读取独立navigation.yml。
迁移要点:
- 把原
navigation.yml的数组内容移动到config/user/site.yml的navigation:字段下。 - 书签导入流程也只会更新
config/user/site.yml,不会再尝试写入/更新navigation.yml。
1.3 不再支持 pages/home.yml -> 顶层 config.categories 与 home 子菜单特例
- 旧版本存在“首页写死叫
home”的遗留逻辑:- 若存在
pages/home.yml,会把其categories复制到顶层config.categories - 生成导航子菜单时,若
nav.id === 'home',会优先从config.categories取分类
- 若存在
- 当前版本:不再维护上述特殊字段/特例;子菜单统一从
pages/<id>.yml的categories读取。
迁移要点:
- 不要依赖
home这个固定 id。 - 首页始终由
site.yml -> navigation的第一项决定;其分类应写在对应的pages/<homePageId>.yml中。
2. 快速迁移清单(建议按顺序执行)
- 确保存在
config/user/site.yml - 确保
config/user/site.yml内包含navigation:(数组) - 确保每个
navigation[].id(除内置search-results)都有对应的config/user/pages/<id>.yml(可缺省,但缺省时页面内容为空) - 若你曾使用
config.yml/config.yaml:将其内容迁移到模块化目录 - 若你曾使用
navigation.yml:迁移到site.yml -> navigation,并删除navigation.yml(可选)
提示:配置采用“完全替换”策略,一旦存在
config/user/就不会回退到config/_default/补齐缺失项。