尤雨溪官宣 VitePress 1.0,第一个主版本横空出世!

大家好,这里是大家的林语冰。

是的没错,那个男人又双叒叕出手了。这次他带来的是 VitePress 1.0,以及颜值爆表的旅拍。

不久前,尤大在朋友圈十分鸡冻地爆料,VitePress 1.0 正式发布,这也是 VitePress 诞生以来升级的第一个语义化主版本,一个值得纪念的里程碑。

然后,尤大就跑路去旅游了,一边移动办公,一边摆拍洱海。果不其然,码生如逆旅,bug 和 life,总要有一个在路上。

作为沉迷学习的 UP 主,我只能一边偷看尤大的"云旅行"流口水,一边啪啪啪码字,给大家科普一下 VitePress。

既然没法偷得浮生半日闲,不如就静下心来深度学习一下:

  • VitePress 到底是什么鬼物?
  • VitePress 和 VuePress 有何区别?
  • 我们可以用 VitePress 来搞什么事情?

VitePress 是什么鬼物?

根据 VitePress 官方文档的简介,VitePress 是一个由 Vite 和 Vue 共同驱动的 SSG(静态站点生成器)。

如果你像我一样,不太清楚 MPA/SPA/SSR/SSG/...... 等一大坨客户端和服务端渲染方式的魔鬼细节,那我们可以用一句话简单理解 VitePress ------ Vue/VueUse/Pinia/Vite/Vitest 等官方文档,都是基于 VitePress 构建的

VitePress 的口号就是将 Markdown 变成优雅的文档,且只需一杯泡面的时间。一杯泡面的时间只需要几分钟,乍一听好像不够持久,但这恰恰是 VitePress 的亮点 ------ 快,而且非常快。

VitePress 的特点在于"内容优先,Markdown 至上",它可以将 Markdown 编写的一切内容,根据应用的主题生成静态 HTML 页面,随时随地部署到地球上。换而言之,VitePress 的设计动机就是构建快速、内容优先的站点。

VitePress vs VuePress

VitePress 和 VuePress 不能说是毫无关系,只能说是大同小异。事实上,VitePress 灵感正是来源于 VuePress。

当然啦,我们都知道 JavaScript 和 Java 的命名也是看起来大同小异,实际上则一龙一猪。既然已有前车之鉴,我们就有必要先瞄一下 VuePress,再比较一下 VuePress vs VitePress 的异同点,从而更系统地学习 VitePress。

根据 VuePress 官方文档的介绍,VuePress 的设计初衷是为了满足 Vue 及其周边生态的文档需求,后来也用于辅助大量用户构建它们的博客和文档等。

VuePress 是一个"Markdown 至上"的 SSG(静态网站生成器)。我们可以使用 Markdown 来撰写文档、博客等,然后 VuePress 会生成一个静态网站来展示它们。

同时,VuePress 可以在一定程度上搞定 Hexo 和 GitBook 等深受程序员群体青睐的文档痛点。

既然 VuePress 如此优秀,为何还要反复造轮子,再孵化出 VitePress 呢?

这是因为,最初的 VuePress 基于 Vue 2 和 webpack。那时的前端工具链中,webpack 还处于垄断地位,后来高产似母猪的尤大又双叒叕孵化了同款竞品 Vite,因为 webpack 在构建 Vue 源码等大型项目时实在是太慢了。

起初 Vite 并没有一夜爆火,但一直在稳定迭代,直到近几年,各大前端生态都开始拥抱 Vite,Vite 真正找到了流量密码。

Vite 原本也没有和 Vue 强耦合,所以可以作为独立的前端工具链无缝衔接。如今,Vite 5 性能已经已经翻了几番,未来规划还会"锈化",使用 Rust 重构底层功能,敬请期待。

VitePress 也随着 Vite 应运而生。虽然今天尤大官宣的是 VitePress 的第一个主版本升级,但 VitePress 这个项目其实从 2019 年就开始迭代了。借助 Vue 3 和 Vite,VitePress 提供了更好的开发体验和生产性能。

除了早期的构建工具差别,VitePress 和 VuePress 的 API 区别主要在于主题和自定义。如果您之前使用的是默认主题的 VuePress 1,那么迁移到 VitePress 应该会比较丝滑。

目前 VuePress 2 也在维护状态,它也支持 Vue 3 和 Vite,与 VuePress 1 的兼容性比 VitePress 更好。

我不确定 VuePress GitHub 仓库提及的"maintenance mode"(维护模式)的确切含义,比如只维持现状、不更新新功能等,如果你知道,记得在评论区留言科普一下。

虽然但是,同时维护两个 SSG 项目并不现实,哪怕尤大很能肝,Vue 团队也肝不动了。因此,Vue 团队决定重点关注 VitePress,将其作为长期维护的主要 SSG 选择。

为什么要选择使用 VitePress ?

VuePress 构建时,会为站点创建一个 SSR(服务端渲染)的版本,然后通过虚拟访问每一条路径来渲染对应的 HTML。这种方案的灵感来源于 Nuxt 和 Gatsby 等项目,VitePress 大抵也是如此。

事实上,Nuxt 几乎可以完美取代 VuePress 或 VitePress,但 Nuxt 是为构建 App 而生的,而 VitePress 的产品定位则更关注轻量化、内容优先的静态网站。

此外,VitePress 的文档更亲民,且由于 VitePress 比 Nuxt 这种元框架更轻量,学习成本也较低。

性能方面,VitePress 已经有详细的设计说明。传统的 SSG 每次导航都会导致页面完全重载,VitePress 的 SSG 会在首次访问时提供静态 HTML,再变成了 SPA(单页应用程序)进行站内的后续导航,包括但不限于:

  • 初始加载很快
  • 加载完毕后快速切换
  • 高效的交互

至于 VuePress,VitePress 可以视为 VuePress 的孪生兄弟。但 VitePress 比 VuePress 更轻更快,但它在灵活性和可配置性上有所权衡,比如 VitePress 不支持插件系统。所以,如果你没有进阶的定制化需求,VitePress 已经足够将你的内容部署到线上。

如果你想构建和部署自己的个人博客或项目文档,VitePress 愿意为您效劳,而且你可以按需自定义主题,进行更细粒度的定制。尤其是如果你本身就熟悉 Vue + Vite 生态,那么使用起来会更加得心应手。

本期话题是 ------ 你有没有想推荐的 SSG 框架?

欢迎在本文下方自由言论,文明共享。谢谢大家的点赞,掰掰~

《前端猫猫教》每日 9 点半更新,坚持阅读,自律打卡,每天一次,进步一点。

相关推荐
三天不学习1 小时前
CSS 之 position 定位属性详解
前端·css·定位·position
亦可呀2 小时前
HTML-CSS-常见标签与样式
前端·css·html
web150850966413 小时前
【MsSQL】数据库基础 & 库的基本操作
前端·数据库·sqlserver
纳尼亚awsl3 小时前
处理元素卡在视野边界,滚动到视野内
前端·javascript·vue.js
黑客Jack3 小时前
XSS Challenges
前端·javascript·xss
黑客-秋凌3 小时前
XSS讲解
前端·xss
永远不会太晚4 小时前
JavaScript的diff库详解(示例:vue项目实现两段字符串比对标黄功能)
前端·javascript·vue.js
Json____4 小时前
网页单机版五子棋小游戏项目练习-初学前端可用于练习~
前端·javascript·css·html·五子棋·网页五子棋单机小程序
lecepin4 小时前
前端技术月刊-2025.1
前端·javascript·面试
maply6 小时前
快速将一个项目的 `package.json` 中的所有模块更新到最新版本
前端·javascript·后端·typescript·npm·node.js·json