116、【Ubuntu】【Hugo】首页板块配置:Leaf Bundle

【声明】本博客所有内容均为个人业余时间创作,所述技术案例均来自公开开源项目(如Github,Apache基金会),不涉及任何企业机密或未公开技术,如有侵权请联系删除

背景

上篇 blog
【Ubuntu】【Hugo】搭建私人博客:搜索功能配置

分析了搜索功能的配置,以及搜索功能关键的索引文件 index.json,下面继续分析下一个功能项(首页板块功能)

搭建私人博客

首先来看下当前首页的情况

可以看到,首页空空如也,只有欢迎信息,只有进入到全部分类,才能看到编辑了的文章

OK,先来分析首页的渲染机制,首页内容一般是 Hugo 的内容组织机制(Hugo 本身默认行为,通用性)和主题配置共同作用的结果(主题行为,特殊性)

首先,首页 Homepage 是一个特殊的 section,其首页模板是 layouts/index.html (不过 PaperMod 并没有使用 index.html 作为其首页模板内容,这个后面再分析),Hugo 本身不会自动决定哪些文章要显示在首页,这完全由用户写的模板,或者使用的主题决定

默认情况下,Hugo 只渲染 content/ 下的叶子 Bundle 或特定内容到首页(当然,这些叶子 Bundle 也需要模板配合用户设置进行实现),Hugo 首页一般只会显示

  • content/index.md(首页专用)
  • Leaf Bundle(具体的文章)
  • Branch Bundle(某一板块)
  • hugo.toml 中配置的菜单项 [[menu.main]]

关于 Page Bundle 的内容,之前 blog 【Ubuntu】【Hugo】搭建私人博客:Page Bundle 已经介绍过,Leaf Bundle 和 Branch Bundle 都是 Page Bundle 的子集

下面来说下 Leaf Bundle,关于 Leaf Bundle 的官方描述如下 https://gohugo.io/content-management/page-bundles/#leaf-bundles

在 Hugo 中,Leaf Bundle 是一个文件夹,里面可以包含其他资源文件(比如图片,附件,额外的 Markdown 文件等),也可以不包含,但必须包含一个 index.md 文件另外,也不能包含其他子文件夹(即不能再有子 bundle),因为 Leaf Bundle 已经是叶子了,没有后代,就好比一棵树,branch 枝干可以继续分叉,但 leaf 叶子是末端,不能再长出新的,示例如下

bash 复制代码
content/
├── about
│   └── index.md
├── posts
│   ├── my-post
│   │   ├── content-1.md
│   │   ├── content-2.md
│   │   ├── image-1.jpg
│   │   ├── image-2.png
│   │   └── index.md
│   └── my-other-post
│       └── index.md
└── another-section
    ├── foo.md
    └── not-a-leaf-bundle
        ├── bar.md
        └── another-leaf-bundle
            └── index.md

在这里,总共有 4 个 Leaf Bundles:

  • about:有 index.md,无子目录
  • my-post:有 index.md + 其他资源
  • my-other-post:只有 index.md
  • another-leaf-bundle:有 index.md,且无子目录

另外,关于 Bundle 中的资源,比如在 my-post 这个 Leaf Bundle 中,除了 index.md,还有

  • content-1.mdcontent-2.md 等被 Hugo 视为 page 类型资源(page 资源不会单独生成网页,但可以通过 .Resources 在模板中被调用)
  • image-1.jpgimage-2.png 等被视为 image 类型资源,同样可以通过 .Resources 进行访问

可以看到,这些额外的 .md 文件不会被 Hugo 单独渲染成独立页面,只是属于该 Bundle 下的附属资源

总结几个 Leaf Bundle 的特点

  • Leaf Bundle = 文件夹 + index.md
  • 不能包含子 Bundle(即其子文件夹里不能还有 index.md
  • 可以放在 content/ 目录下的任意深度(比如 content/a/b/c/index.md 也是合法的 Leaf Bundle)
  • 里面的非 index.md 文件都属于资源,不是独立页面

OK,本篇先到这里,如有疑问,欢迎评论区留言讨论,祝各位功力大涨,技术更上一层楼!!!更多内容见下篇 blog
【Ubuntu】【Hugo】首页板块配置:Branch Bundle

相关推荐
上天_去_做颗惺星 EVE_BLUE35 分钟前
【新 Linux 服务器上手全攻略】系统巡检、存储规划与开发环境初始化
linux·运维·服务器·ubuntu·macos·centos
das2m1 小时前
WSL2 Ubuntu 配置完美版 docker compose 指南
linux·ubuntu·docker
MIXLLRED1 小时前
Ubuntu 22.04 + ROS2 Humble 上部署 ScaRF‑SLAM指南
ubuntu·slam·ros2·离线建图
FlyWIHTSKY2 小时前
JavaScript 和 TypeScript 分别是什么,可以相互写吗
javascript·ubuntu·typescript
iRayCheung2 小时前
virtualbox安装的ubuntu系统跑numpy报错
linux·ubuntu·numpy
丑过三八线3 小时前
Systemd Cgroup 驱动详解
linux·ubuntu·容器
指尖在键盘上舞动4 小时前
RKNN 模型部署:onnx转rknn后精度下降 —— 精度调优与问题排查
python·ubuntu·rk3588·rknn·onnx·npu
2601_961194024 小时前
考研专业课在哪里参加考试|考点|流程|资料已整理
linux·考研·ubuntu·缓存·centos·负载均衡
dust_and_stars5 小时前
ubuntu24 suspend以后重新打开,桌面打不开了
ubuntu
半壶清水21 小时前
ubuntu下利用ns-3 + NetAnim搭建可视化路由选路过程的方法
linux·运维·ubuntu