从 v1 迁移
配置项变化
以下选项已被删除,应通过 插件 实现:
resolvers
transforms
indexHtmlTransforms
jsx
和enableEsbuild
都已被删除,请使用新的esbuild
选项。CSS 相关选项 都被包含在
css
字段下。所有 用于构建的选项 现在都在
build
字段下。rollupInputOptions
和rollupOutputOptions
已经被build.rollupOptions
替代。esbuildTarget
现在是build.target
emitManifest
现在是build.manifest
- 以下构建选项已经被移除,因为它们可以通过插件钩子或其他选项实现:
entry
rollupDedupe
emitAssets
emitIndex
shouldPreload
configureBuild
所有的 server-specific options 现在都在
server
字段下。hostname
现在是server.host
httpsOptions
已被删除,server.https
可以直接接收选项对象。chokidarWatchOptions
现在是server.watch
assetsInclude
现在接收string | RegExp | (string | RegExp)[]
而不是一个函数。所有 Vue 特定选项都已删除;应将选项传递给 Vue 插件。
别名用法变化
alias
现在会被传递给 @rollup/plugin-alias
并不再需要开始/结尾处的斜线了。此行为目前是一个直接替换,所以 1.0 风格的目录别名需要删除其结尾处的斜线:
- alias: { '/@foo/': path.resolve(__dirname, 'some-special-dir') }
+ alias: { '/@foo': path.resolve(__dirname, 'some-special-dir') }
另外,你可以对该选项使用 [{ find: RegExp, replacement: string }]
格式以求更精确的控制。
Vue Support
Vite 2.0 核心已经是框架无关的了。对 Vue 的支持目前详见 @vitejs/plugin-vue
。安装它并添加到 Vite 配置十分简单:
import vue from '@vitejs/plugin-vue'
export default {
plugins: [vue()]
}
自定义块转换
一个自定义插件可以用来转换 Vue 自定义块,如下所示:
// vite.config.js
import vue from '@vitejs/plugin-vue'
const vueI18nPlugin = {
name: 'vue-i18n',
transform(code, id) {
if (!/vue&type=i18n/.test(id)) {
return
}
if (/\.ya?ml$/.test(id)) {
code = JSON.stringify(require('js-yaml').safeLoad(code.trim()))
}
return `export default Comp => {
Comp.i18n = ${code}
}`
}
}
export default {
plugins: [vue(), vueI18nPlugin]
}
React 支持
React Fast Refresh 现已支持,详见 @vitejs/plugin-react-refresh
。
HMR API 变化
import.meta.hot.acceptDeps()
已经弃用。import.meta.hot.accept()
现在可以接收一个或多个依赖。
Manifest 格式变化
构建清单现在使用以下格式:
{
"index.js": {
"file": "assets/index.acaf2b48.js",
"imports": [...]
},
"index.css": {
"file": "assets/index.7b7dbd85.css"
}
"asset.png": {
"file": "assets/asset.0ab0f9cd.png"
}
}
对于入口 JS chunk,它还列出了它导入的 chunk,这些 chunk 可以用来渲染预加载指令。
写给插件作者
Vite 2 使用了一套完全重定义的,扩展了 Rollup 插件的接口。请阅读新的 插件开发指南.
一些将 v1 插件迁移到 v2 的提示:
resolvers
-> 使用resolveId
钩子transforms
-> 使用transform
钩子indexHtmlTransforms
-> 使用transformIndexHtml
钩子- 虚拟文件支持 -> 使用
resolveId
+load
钩子 - 添加
alias
,define
或其他配置项 -> 使用config
钩子
由于大多数逻辑应该通过插件钩子而不是中间件来完成,因此对中间件的需求大大减少。内部服务器应用现在是一个很好的旧版的 connect 实例,而不是 Koa。