86、【Ubuntu】【Hugo】搭建私人博客:TOC 配置&侧边导航栏

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

背景

上篇 blog
【Ubuntu】【Hugo】搭建私人博客:文章目录(三)

分析了【初始化嵌套 <ul> 结构】中的 <ul><li><ol>bareul 标签,下面继续

搭建私人博客

OK,分析完这些,可以知道,Hugo PaperMod 模板本身已经提供了一套 TOC 机制,下面只要应用即可,打开 hugo.toml 配置文件,加入配置项 ShowToc = true

接着终端输入

bash 复制代码
hugo server

启动 Hugo 博客,可以看到 TOC 效果如下

往下滑之后,右下角有个链接可以快速回到目录上面

OK,这样 PaperMod 主题的 TOC 功能配置完成

接下来,再添加下一个功能【导航栏】

首先,可以看到博客左部的空间是很空旷的

这是因为 PaperMod 主题是基于原版 Paper 主题改进而来的,继承了其干净,简洁,专注内容的设计理念,属于极简主义风格,其页面布局以中间的单栏为主,减少视觉干扰,可以让读者更专注于文章内容本身,尤其适合博客,技术笔记,写作类的网站

当然,文章数量少的时候,这样是没问题的,但当文章数量多到一定程度时,侧边导航栏的作用就会体现出来,可以让用户瞬间能够跳转到下一篇喜欢的文章

首先,PaperMod 主题是没有侧边导航栏的模板的,因为其设计风格就是单栏,为了实现侧边导航栏的目标,开发者可以自定义添加,主要通过

  • 修改 layouts/ (博客目录下,非主题目录)中的模板文件(比如 single.html
  • 使用 Hugo 的 partial 机制引入自定义侧边栏组件
  • 覆盖 CSS 样式,创建侧边导航栏布局

下面将详细介绍下侧边导航栏的设计添加

在介绍侧边导航栏之前,先回顾之前之前在 custom.css 文件中自定义的行内代码颜色更改内容

css 复制代码
/* 强制覆盖所有行内代码样式 */
.post-content code,
main code,
article code {
  color: #d32f2f !important;        /* 红色文字 */
  background-color: #ffebee !important; /* 淡红背景 */
  padding: 0.2em 0.4em !important;
  border-radius: 4px !important;
  font-size: 0.95em !important;
  font-family: "Fira Code", "JetBrains Mono", Consolas, "Courier New", monospace !important;
}

下面先解释完这里的东西再继续,首先是其核心目标,这段 CSS 代码可以强制统一网页中所有的 inline code(行内代码)的显示样式,无论这些代码原本被什么 HTML 元素包裹,是否被其他样式覆盖,这里有几个关键点:

  • 选择器部分.post-content codemain codearticle code 都是选择器,表示选中 class 为 .post-content 容器内的 <code> 标签,以及在 <main><article> 标签内的 <code> 标签,这些一般是博客或文章内容中行内代码容易出现的位置,这里提到的 <code> 标签在 HTML 中用于表示一段计算机代码,当 <code> 不被 <pre> 包裹时,一般就是行内代码
  • color: #d32f2f !important :样式规则,表示文字颜色为深红色 #d32f2f,并用 !important 强制覆盖其他可能得 color 设置
  • background-color: #ffebee !important :背景色设置成非常浅的粉红色 #ffebee,形成高亮效果,同样强制生效
  • padding: 0.2em 0.4em !important:内边距设置成上下 0.2 倍字体高度,左右 0.4 倍,让文字不紧贴边框,更美观
  • border-radius: 4px !important:圆角边框,让背景块看起来更柔和
  • font-size: 0.95em !important:字体略小于正文(95%),避免行内代码显得突兀
  • font-family: "...", monospace !important:使用等款字体(monospace),有限使用现代编程字体,比如 Fira Code,JetBrains,Mono 等,提升代码可读性,如果电脑没有安装这些字体,会依次回退到 Consolas,Courier New,最后用系统默认等宽字体

OK,本篇先到这里,如有疑问,欢迎评论区留言讨论,祝各位功力大涨,技术更上一层楼!!!更多内容见下篇 blog
【Ubuntu】【Hugo】搭建私人博客:侧边导航栏(一)

相关推荐
小羽网安2 分钟前
Linux 服务器如何进行安全加固?
linux·服务器·安全
倔强的胖蚂蚁9 分钟前
AI 人工智能配置管理 Nginx
运维·nginx·云原生
上海云盾安全满满14 分钟前
服务器如果做好日常维护,有什么作用
运维·服务器
正在走向自律18 分钟前
企业级数据库存储运维实战:表空间自动创建与存储架构深度优化
运维·数据库·架构·表空间
念风25 分钟前
[Linux学习笔记]Uboot-DM的分析过程
linux
想唱rap31 分钟前
计算机网络基础
linux·计算机网络·mysql·ubuntu·bash
Agent产品评测局40 分钟前
图片生成智能体哪家好?2026年企业级视觉创作与自动化选型全景横评
运维·人工智能·ai·自动化
fetasty42 分钟前
chroot的Linux服务配置-当云服务器真正用起来
android·linux·服务器
猫头虎-人工智能44 分钟前
ToDesk ToClaw AI自动化实测:零门槛玩转日常自动化,告别折腾与硬件损耗
运维·人工智能·架构·开源·自动化·aigc·ai编程
实在智能RPA44 分钟前
Agent 能做流程的自动化监控吗?——深度拆解2026年AI智能体在企业级闭环监控中的技术实践
运维·人工智能·ai·自动化