Vite 3.0 发布,下一代的前端工具链
距离 v2 发布 16 个月后,Vite 3.0 现已正式发布。公告指出,去年 2 月 Vite 2 发布以来,其采用率就在不断增长;每周 npm 下载量超过 100 万次,迅速形成了庞大的生态系统。Vite 正在推动 Web 框架的新一轮创新竞赛。
“我们决定至少每年发布一个新的 Vite 主要版本,以配合 Node.js 的 EOL,并借此机会定期审查 Vite 的 API,为生态系统中的项目提供简短的迁移路径。”
Vite 3.0 更新内容主要包括:
新文档
可前往 vitejs.dev 使用新的 v3 文档。Vite 现在使用新的 VitePress 默认主题,在其他 features 之间具有一个 Dark 模式。
生态系统中的几个项目已经迁移到这里(参见 Vitest、vite-plugin-pwa 和 VitePress 本身)。如果你需要访问 Vite 2 文档,它们将保留在 v2.vitejs.dev。还有一个新的 main.vitejs.dev 子域,其中对 Vite 主分支的每个提交都是自动部署的。这在测试 beta 版本或为核心开发做出贡献时很有用。
以及添加了一个正式的西班牙语翻译:
创建 Vite Starter Templates
create-vite 模板是一个很好的工具,可以用你最喜欢的框架快速测试 Vite。在 Vite 3 中,所有的模板都有一个与新文档一致的新主题。在线打开它们并立即开始使用 Vite 3:
现在所有模板都共享这个主题。对于更完整的解决方案,包括 linting、测试设置和其他功能;有一些框架的官方 Vite-powered 模板,如 create-vue 和 create-svelte。在 Awesome Vite 有一个由社区维护的模板列表。
开发改进
Vite CLI
VITE v3.0.0 ready in 320 ms ➜ Local: http://127.0.0.1:5173/ ➜ Network: use --host to expose
除了 CLI 的美学改进之外,默认的开发服务器端口现在是 5173,预览服务器监听端口是 4173。此更改将确保 Vite 将避免与其他工具发生冲突。
改进的 WebSocket 连接策略
Vite 2 的痛点之一是在代理后面运行时配置服务器。Vite 3 更改了默认的连接方案,因此它在大多数情况下都是开箱即用的。所有这些设置现在都通过vite-setup-catalogue
作为 Vite Ecosystem CI 的一部分进行测试。
冷启动改进
Vite 现在可以避免在冷启动期间,当插件在抓取初始静态导入的模块时注入导入时完全重新加载(#8869)。
import.meta.glob
import.meta.glob
支持被重写。可阅读 Glob Import Guide 中的新功能:
多个模式可以作为数组传递
import.meta.glob(['./dir/*.js', './another/*.js'])
现在支持 Negative Patterns(以!
为前缀)以忽略某些特定文件
import.meta.glob(['./dir/*.js', '!**/bar.js'])
可以指定 Named Imports 以改进 tree-shaking
import.meta.glob('./dir/*.js', { import: 'setup' })
import.meta.glob('./dir/*.js', { query: { custom: 'data' } })
Eager Imports 现在作为一个 flag 传递
import.meta.glob('./dir/*.js', { eager: true })
使 WASM Import 与 Future Standards 保持一致
WebAssembly Import API 已经过修订,以避免与 Future Standards 发生冲突并使其更加灵活:
import init from './example.wasm?init'
init().then((instance) => {
instance.exports.test()
})
在 WebAssembly guide 中了解更多信息。
构建改进
ESM SSR 默认构建
生态系统中的大多数 SSR 框架已经在使用 ESM 构建。因此,Vite 3 使 ESM 成为 SSR 构建的默认格式。这使得可以简化以前的 SSR 外部化启发式方法,默认情况下外部化依赖项。
改进的 Relative Base 支持
Vite 3 现在正确支持 relative base(使用base: ''
),允许将构建的资产部署到不同的 bases 而无需重新构建。这在构建时不知道 base 的情况下非常有用,例如在部署到 IPFS 等内容可寻址网络时。
减少捆绑包大小
Vite 捆绑了它的大部分依赖项,并尽可能地尝试使用现代轻量级替代方案。Vite 3 的发布大小比 V2 小了 30%。
错误修复
在过去的三个月里,Vite 的 open issues 从 770 个减少到了 400 个。
兼容性说明
- Vite 不再支持已达到 EOL 的 Node.js 12。现在需要 Node.js 14.18+。
- Vite 现在以 ESM 的形式发布,为了兼容,在 ESM entry 中加入了 CJS 代理。
- Modern Browser Baseline 现在针对支持原生 ES 模块、原生 ESM 动态导入和特性的浏览器以支持原生 ES 模块、原生 ESM 动态导入和
import.meta
功能的浏览器为目标。 - SSR 和 library 模式下的 JS 文件扩展名现在使用有效的扩展名(js、mjs 或 cjs)来输出基于其格式和包类型的JS entries 和 chunks。
在迁移指南中了解更多信息。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
PowerToys v0.60.1 已发布
PowerToys v0.60.1 已发布,这是一个补丁版本,用于修复 v0.60.0 中的问题,以修复一些对稳定性很重要的错误。 #19253 - 更新了 PowerToys 的 Microsoft Store 提交,在安装时不显示 UI。 #19023 - 修复了当多个显示器共享相同序列号时,导致 FancyZones 无法正确应用模板的错误。 #19233 - 修复了 PowerRename 和 ImageResizer Windows 11 第 1 层上下文菜单在开发内幕上的不兼容性问题。 #19219 - 旧的上下文菜单现在也显示在 Windows 11 上,以说明其他第三方软件可能覆盖 Windows 11 上下文菜单的配置。 #19263 - 修复了在屏幕左上角激活“查找我的鼠标”覆盖时挂起的错误。 #19223 - FancyZones 编辑器在未检测到显示器连接的配置上崩溃的问题。 更新公告:https://github.com/microsoft/PowerToys/releases/tag/v0.60.1
-
下一篇
Spring Native 0.12.1 发布
Spring Native 0.12.1 已发布,这是一个常规更新版本,主要是修复错误、升级依赖,以及增加部分特性。 新特性 为 Sleuth R2dbcTransactionManager 检测工具添加提示#1663 优化兼容性 支持 R2DBC PostgreSQL#1626 支持 EntityGraph#1619 为 com.zaxxer.hikari.HikariDataSource 添加 reflection entries #1599 升级依赖项 Native Build Tools 0.9.13#1638 Spring Boot 2.7.1#1637 Bug Fixes 修复无法识别类在构建时初始化的 InitializationHint#1660 修复 (Simple)ClientHttpRequestFactory 中关于 Nativehints 的回归错误#1636 修复没有在 NativeListener 中设置原生图像系统属性的问题#1625 修复 jdbc-tx 测试在 GraalVM 22.1 中没有生效的问题#1584 修复 AOP 不支持在包含 exec...
相关文章
文章评论
共有0条评论来说两句吧...