我们和 webpack 团队确立了合作关系,Rspack 是 webpack 通过 Rust 进行性能优化的一个尝试,并已经取得了良好进展。
我们会和 webpack 团队持续探索优化 webpack 的更多可能性。
我们更重视以较低的迁移成本为现有的 web 项目带来性能提升,而不是单纯追求 benchmark 指标。
兼容 webpack 生态会带来一定的性能损失,但是根据我们的验证结果,这个损失在可接受范围内。
Rspack 内部使用 SWC 进行代码的降级编译(通过 builtin:swc-loader),因此无需通过 babel-loader 来进行代码的降级编译。
不是,Rspack 目标不是完全兼容 100% 的 webpack API,根据二八定律的原则,我们优先实现了在大部分项目里高频使用的 API,并根据用户需求来进一步支持其他 API。
计划支持,我们和 NAPI-RS 团队一起在探索 Wasm 方案,目前还在探索阶段,后续会有更多的进展。
虽然 webpack + SWC-loader 解决了 babel-loader 的性能问题,但 webpack 本身仍然存在较多的性能瓶颈,如 make,seal 等阶段都是单线程的,而 Rspack 突破了这些限制,因此 Rspack 比 webpack + SWC-loader 有更好的性能表现,尤其是在多核场景。
不需要,你可以像开发 webpack 插件和 loader 一样,使用 JavaScript 来开发插件和 loader。同时我们也在探索如何支持用户使用 Rust 开发自定义的插件和 loader。
Rspack 将会支持 React Server Components。目前我们已经在一个内部项目中实验性尝试了 Rspack + RSC,并获得了明显的性能提升。
相关 PR:#5824。
可以,目前我们已经在大量的内部项目中使用 Rspack 构建,并在生产环境平稳运行。
我们目标是让 Rspack 生成的运行时代码完全对齐 Webpack(意味着你很难从产物里判断是 webpack 还是 Rspack 产物),虽然目前尚未达到完整对齐状态,我们将持续完善 runtime 并最终达到完全对齐状态。