Vite 4.0 发布,下一代的前端工具链
继在五个月前发布 Vite 3 后,现在 Vite 4 正式发布。如今 npm 每周的下载量从 100 万上升到 250 万,并继续保持增长。在今年的 Jamstack Conf 调查中,社区中的使用率从 14% 跃升至 32%,同时保持了 9.7 分的高满意度。
主要变化
与 Vite 3 相比,这个主要版本的更新幅度较小,主要目的是升级到 Rollup 3。我们已经与 Vite 生态中的各方合作,确保这个新的主要版本有一个平滑的升级路径。
Rollup 3
Vite 现在使用 Rollup 3,它让我们简化了 Vite 的内部资源处理,并有许多改进。点击这里查看 Rollup 3 更新说明。
框架插件脱离了 Vite core monorepo
@vitejs/plugin-vue
和 @vitejs/plugin-react
从 Vite 的第一个版本开始就是 Vite core monorepo 的一部分。这有助于我们在进行修改时获得一个紧密的反馈回路,因为我们同时得到了 Core 和插件的测试和发布。借助 Vite-ecosystem-ci
,我们可以通过这些在独立仓库中开发的插件获得这种反馈。因此从 Vite 4 开始,它们已经从 Vite core monorepo 中移出。
开发过程中使用 SWC 的新 React 插件
SWC 现在是 Babel 的成熟替代品,特别是在 React 项目的背景下。SWC 的 React Fast Refresh 实现比 Babel 快很多,对于一些项目来说,它现在是一个更好的选择。从 Vite 4 开始,有两个插件可用于 React 项目,他们各自都有不同的取舍和权衡。我们认为目前这两种方法都值得支持,未来我们会继续探索对这两个插件的改进。
@vitejs/plugin-react
@vitejs/plugin-react
是一个使用 esbuild 和 Babel 的插件,能够以占用空间小的软件包和灵活使用 babel transform pipeline 实现快速的 HMR
@vitejs/plugin-react-swc (新)
@vitejs/plugin-react-swc
是一个新的插件,在构建过程中使用 esbuild,但在开发过程中用 SWC 取代 Babel。对于不需要非标准 React 扩展的大项目,冷启动和 HMR 的速度会明显加快。
兼容性
现代浏览器构建现在默认以 safari14
为目标,以实现更广泛的 ES2020 兼容性。这意味着,现代构建现在可以使用 BigInt
,并且空值合并运算符(nullish coallessing operator)不再被转译。如果你需要支持旧的浏览器,你可以像往常一样添加 @vitejs/plugin-legacy
。
以字符串形式导入 CSS
在 Vite 3 中,导入默认导出的 .css
文件可能会带来 CSS 的重复加载。
import cssString from './global.css';
从 Vite 4 开始,.css
默认导出已被废弃。在这样的情况下,需要使用 ?inline
查询后缀修饰符,因为它不会发出导入的 .css
样式。
import stuff from './global.css?inline'
其他功能
- 预捆绑依赖项时支持 patch-package
- 更加干净的构建日志输出,并切换到
kB
,以与浏览器开发工具保持一致 - 改进了 SSR 过程中的错误信息
快速链接:
不同语言的文档:

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Apache NetBeans 16 发布
Apache NetBeans 是顶级的 Apache 项目,是一个开源的开发环境、工具平台和应用框架,可以满足开发者、用户和依靠 NetBeans 作为产品基础的企业的需求,使他们能够快速、有效、轻松地开发产品。 Gradle 在 Gradle 中初步实现(实验性的)Dependency API 将 Grade Editor 相关功能重构为 gradle.editor 模块 Gradle 隐藏空的生成文件夹 支持没有 build.gradle 的项目 修复 gradle build actions 对话框中的 npe 各种修复和改进 将 gradle.dist 和 gradle.editor 模块切换为常规 保护对 gradle 内部 API 的访问,避免项目加载失败 …… Maven 改进 Jakarta EE 9/9.1 的支持 修复 NexusRepositoryIndexerImpl 异常处理程序中可能出现的NPE 为 Jakarta EE 9.1 更新 Maven 原型版本 Maven UseReleaseOptionHint 修复 Maven HintsPanel UI ...
- 下一篇
用 Java?试试国产轻量的 Solon v1.11.4(带视频)
一个更现代感的 Java 应用开发框架:更快、更小、更自由。没有 Spring,没有 Servlet,没有 JavaEE;独立的轻量生态。主框架仅 0.1 MB。 @Controller public class App { public static void main(String[] args) { Solon.start(App.class, args); } @Get @Socket @Mapping("/hello") public String hello(@Param(defaultValue = "java") String name) { return String.format("Hello %s!", name); } } 入门探索视频(用户录制): 相对于 Spring Boot 和 Spring Cloud 的项目: 启动快 5 ~ 10 倍。 (更快) qps 高 2~ 3 倍。 (更高) 运行时内存节省 1/3 ~ 1/2。 (更少) 打包可以缩小到 1/2 ~ 1/10;比如,300Mb 的变成了 23Mb。 (更小) ...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Red5直播服务器,属于Java语言的直播服务器
- CentOS7设置SWAP分区,小内存服务器的救世主
- CentOS7安装Docker,走上虚拟化容器引擎之路
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS关闭SELinux安全模块
- CentOS7,CentOS8安装Elasticsearch6.8.6
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Linux系统CentOS6、CentOS7手动修改IP地址
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16