从 v1 迁移
注意
VuePress v1 的插件和主题与 VuePress v2 不兼容。你需要将它们升级到与 v2 对应的版本。
VuePress v2 的一些主要改动和优化:
- VuePress v2 现在使用 Vue 3 ,因此你要保证你的组件和其他客户端文件是适用于 Vue 3 的。
- VuePress v2 是使用 TypeScript 开发的,因此它现在提供了更好的类型支持。我们强烈推荐你使用 TypeScript 来开发插件和主题。 VuePress 配置文件也同样支持 TypeScript ,你可以直接使用
.vuepress/config.ts
。 - VuePress v2 支持使用 Webpack 和 Vite 作为打包工具。你甚至可以在开发模式使用 Vite 来获取更好的开发体验,而在构建模式使用 Webpack 来获取更好的浏览器兼容性。
VuePress v2 的核心思想和流程是和 v1 一致的,但 v2 API 经过了重新设计,更加标准化。因此在将现有的 v1 项目迁移至 v2 时,你很可能会遇到一些 Breaking Changes 。本指南将帮助你将 v1 的站点 / 插件 / 主题迁移至 v2 。
给用户
用户配置变更
shouldPrefetch
默认值从 () => true
更改为 false
。
extraWatchFiles
移除。
你可以手动在 onWatched Hook 中监听文件变化。
patterns
重命名为 pagePatterns
。
plugins
只允许 Babel 式在新窗口打开 选项。
v2 不再支持 对象式在新窗口打开 选项。
markdown.lineNumbers
移动至 markdown.code.lineNumbers 。
默认值从 false
更改为 true
。
markdown.slugify
移除。
如果你无论如何都要修改 slugify 函数,分别设置以下选项:
markdown.anchor.slugify
markdown.toc.slugify
markdown.extractHeaders.slugify
markdown.pageSuffix
移除。
markdown.externalLinks
移动至 markdown.links.externalAttrs 。
markdown.toc
有改动。
markdown.plugins
移除。
在 extendsMarkdown Hook 中使用 markdown-it 插件。
markdown.extendMarkdown
移除。
使用 extendsMarkdown Hook 。
markdown.extractHeaders
有修改。
参考 配置 > markdown.extractHeaders
Webpack 相关配置
所有 Webpack 相关的配置都移动至 @vuepress/bundler-webpack
的配置项中,所以你需要在 bundlerConfig 中设置它们:
postcss
:移动至bundlerConfig.postcss
stylus
:移动至bundlerConfig.stylus
scss
:移动至bundlerConfig.scss
sass
:移动至bundlerConfig.sass
less
:移动至bundlerConfig.less
chainWebpack
:移动至bundlerConfig.chainWebpack
configureWebpack
:移动至bundlerConfig.configureWebpack
evergreen
:移动至bundlerConfig.evergreen
,且默认值从false
更改为true
。
Frontmatter 变更
meta
移除。
改为使用 head 。例如:
head:
- - meta
- name: foo
content: bar
- - link
- rel: canonical
href: foobar
- - script
- {}
- console.log('hello from frontmatter');
2
3
4
5
6
7
8
9
10
和以下结构相同:
// .vuepress/config.js
module.exports = {
// ...
head: [
['meta', { name: 'foo', content: 'bar' }],
['link', { rel: 'canonical', href: 'foobar' }],
['script', {}, `console.log('hello from frontmatter');`],
],
// ...
}
2
3
4
5
6
7
8
9
10
永久链接 Patterns 变更
:i_month
:移除:i_day
:移除:minutes
:移除(v1 文档中未列出):seconds
:移除(v1 文档中未列出):regular
:重命名为:raw
参考 Frontmatter > permalinkPattern 。
调色板系统变更
VuePress v1 的 Stylus 调色板系统 (即 styles/palette.styl
和 styles/index.styl
) 不再由 VuePress Core 默认提供支持。
调色板系统提取到了 @vuepress/plugin-palette 当中。
主题作者可以使用自己的方式来为用户提供自定义样式的能力,而不必被限制在 Stylus 当中。
如果你使用的是默认主题,那么调色板系统仍然存在,但改为使用 SASS ,并且大部分变量都迁移为 CSS 变量。参考 默认主题 > 样式 。
约定文件变更
.vuepress/enhanceApp.js
重命名为 .vuepress/clientAppEnhance.{js,ts}
。
函数接收的参数也有改动。
参考 客户端 API > defineClientAppEnhance 。
.vuepress/components/
在该目录下的文件不会被自动注册为 Vue 组件。
你需要使用 @vuepress/plugin-register-components ,或者在 .vuepress/clientAppEnhance.{js,ts}
中手动注册你的组件。
.vuepress/theme/
即使该目录存在,也不会被隐式默认当作本地主题目录。
你需要在 theme 配置项中显式声明本地主题的路径。
Markdown 插槽变更
Markdown 插槽不再被支持。
插件 API 变更
plugins
:移除ready
:重命名为onPrepared
updated
:重命名为onWatched
generated
:重命名为onGenerated
additionalPages
:移除,改为在onInitialized
Hook 中使用app.pages.push(createPage())
clientDynamicModules
:移除,改为在onPrepared
Hook 中使用app.writeTemp()
enhanceAppFiles
:重命名为clientAppEnhanceFiles
globalUIComponents
:重命名为clientAppRootComponentFiles
clientRootMixin
:重命名为clientAppSetupFiles
extendMarkdown
:重命名为extendsMarkdown
chainMarkdown
:移除extendPageData
:重命名为extendsPageData
extendsCli
:移除configureWebpack
:移除chainWebpack
:移除beforeDevServer
:移除afterDevServer
:移除
参考 插件 API 。
主题 API 变更
layouts
现在你需要手动设置布局目录或布局组件。
参考 主题 API > layouts 。
extend
重命名为 extends
。
你仍然可以通过 extends: 'parent-theme'
来继承一个父主题,这将会继承其插件和布局等。
@theme
和 @parent-theme
别名不再生效。
现在支持主题的多级继承。
CLI 变更
eject 命令
移除。
cache 选项
-c, --cache [cache]
:修改为--cache <cache>
,意味着-c
不再是cache
选项的缩写,并且cache
选项的值不再是可选的。--no-cache
:重命名为--clean-cache
。
默认主题变更
内置组件
<CodeGroup />
和<CodeBlock />
重命名为<CodeGroup />
和<CodeGroupItem />
<Badge />
$badgeErrorColor
调色板变量重命名为$badgeDangerColor
type
Prop 现在只接受tip
、warning
和danger
调色板系统
默认主题的调色板系统迁移为 SASS 和 CSS 变量。
参考 默认主题 > 样式 。
主题配置
默认主题的配置有大量变更。
参考 默认主题 > 配置 。
官方插件变更
参考 官方插件 。
社区主题和插件
v1 的主题和插件和 v2 并不兼容。
请确保你在使用的主题和插件已经支持 v2 ,并前往它们各自的文档查看迁移指南。
给插件作者
请先浏览 插件 API 变更 。
一些主要的 Breaking Changes :
- 你不能再在你的插件中使用其他插件了,这避免了很多由于插件嵌套引发的问题。如果你的插件依赖于别的插件,你应在文档中列出他们。
- 大部分 v1 Hook 都在 v2 中存在等效的 Hook 或实现方式。唯一的例外是
extendsCli
,它被移除了。 - Webpack 相关的 Hook 都被移除了,因为 VuePress Core 已经和 Webpack 解耦了。如果你仍然想要在插件中修改 Webpack 配置,可以尝试直接修改
app.options.bundlerConfig
。
给主题作者
虽然我们不允许在插件中使用其他插件了,但是你仍然可以在你的主题中使用插件。
一些主要的 Breaking Changes :
- 所谓的 主题目录结构约定 不再存在。
theme/enhanceApp.js
或theme/clientAppEnhance.{js,ts}
文件不会被隐式作为 Client App Enhance 文件。你需要在clientAppEnhanceFiles
Hook 中显式指定它。theme/global-components/
目录下的文件不会被自动注册为 Vue 组件。你需要使用 @vuepress/plugin-register-components ,或者在clientAppEnhance.{js,ts}
中手动注册组件。theme/layouts/
目录下的文件不会被自动注册为布局组件。你需要通过layouts
配置项来显式指定。theme/templates/
目录下的文件不会被自动作为 dev / ssr 的模板。- 你始终需要提供主题入口文件,并且不要使用
"main": "layouts/Layout.vue"
作为主题入口。
- Stylus 不再是默认的 CSS 预处理器,并且 Stylus 调色板系统不再被默认支持。如果你仍然想要使用和 v1 类似的调色板系统,可以使用 @vuepress/plugin-palette 。
- 由 Prism.js 提供的 Markdown 代码块的语法高亮不再被默认支持。你可以选择使用 @vuepress/plugin-prismjs 或 @vuepress/plugin-shiki ,或者用你自己的方式实现语法高亮。
- 考虑到可扩展性,
$site.pages
不再可用。