Skip to content
AstroPaper
Go back

AstroPaper 5.0

Edit page

终于,期待已久的 AstroPaper v5 正式发布了。AstroPaper v5 保持了同样简洁清爽的外观,但底层带来了重大更新。

AstroPaper v5

目录

重大变更

升级到 Astro v5 #455

AstroPaper 现在搭载 Astro v5,带来了随之而来的所有新功能和改进。

Tailwind v4

AstroPaper 已升级到 Tailwind v4,底层包含了许多样式变更。tailwind.config.js 文件已被移除,现在所有配置都位于 src/styles/global.css 文件中。排版相关样式已被提取并移至 src/styles/typography.css

由于 TailwindCSS v4 的新行为,组件内 <style> 块中的样式已被移除,替换为内联 Tailwind 类。

此外,UI 中的颜色调色板已更新。新的调色板现在仅包含五种颜色:

:root,
html[data-theme="light"] {
  --background: #fdfdfd;
  --foreground: #282728;
  --accent: #006cac;
  --muted: #e6e6e6;
  --border: #ece9e9;
}

html[data-theme="dark"] {
  --background: #212737;
  --foreground: #eaedf3;
  --accent: #ff6b01;
  --muted: #343f60bf;
  --border: #ab4b08;
}

移除 React + Fuse.js,改用 Pagefind 搜索

在之前的版本中,React.js 和 Fuse.js 被用于搜索功能和 OG 图片生成。在 AstroPaper v5 中,React.js 已被移除,替换为 Pagefind,一个静态站点搜索工具。

搜索体验与之前版本几乎相同,但得益于 Pagefind,现在所有内容(不仅仅是标题和描述)都会被索引并可搜索。

在开发模式中使用 Pagefind 的想法受这篇博客文章启发。

更新导入别名

导入别名已从 @directory 更新为 @/directory,这意味着你现在需要像这样导入:

---
import { slugifyStr } from "@/utils/slugify";
import IconHash from "@/assets/icons/IconHash.svg";
---

迁移至 pnpm

AstroPaper 已从 npm 切换到 pnpm,提供更快、更高效的包管理。

将图标/SVG 替换为 Astro 的 SVG 组件

AstroPaper v5 将内联 SVG 替换为 Astro 的实验性 SVG 组件。此更新减少了 socialIcons 对象中对预定义 SVG 代码的需求,使代码库更简洁、更易于维护。

分离常量与配置

项目结构已重新组织。src/config.ts 文件现在仅包含 SITE 对象,其中存放项目的主要配置。所有常量,如 LOCALESOCIALSSHARE_LINKS,已移至 src/constants.ts 文件。

其他值得注意的变更

结语

AstroPaper v5 带来了许多变化,但核心体验保持不变。在保持 AstroPaper 一贯的简洁和极简设计的同时,享受更流畅、更高效的博客平台!

欢迎探索这些变化并分享你的想法。一如既往,感谢你的支持!

如果你喜欢这个主题,请考虑为仓库点亮 Star。你也可以通过 GitHub Sponsors 支持我,或者如果你想的话,可以请我喝杯咖啡。当然,这些行为完全是可选的,并非必须。

享受吧!

Sat Naing


Edit page
Share this post on:

Previous Post
How to integrate Giscus comments into AstroPaper
Next Post
How to use Git Hooks to set Created and Modified Dates