新的打包工具 Rsbuild 尝鲜:Vue2-cli 项目迁移 Rsbuild

本文主要是介绍新的打包工具 Rsbuild 尝鲜:Vue2-cli 项目迁移 Rsbuild,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当前时间 2024-08-31

看到一个新的打包工具,于是想试一试,这里是官网

在这里插入图片描述

在这里插入图片描述


测试

用过 vue-cli 的同志们应该有所感受,启动项目挺慢的,我这个项目不太大,第一次启动是最慢的,之后启动快了一些些,而且也是编译了三四次,也花费了六七秒的时间(第一次的时间大概有10多秒,我没录下来)

请添加图片描述

再试试 rsbuild,用了不到 4s,不过对比第一次冷启动还是快了不少的

请添加图片描述


迁移过程

不同脚手架的项目迁移,具体参照的是 官网的迁移

因为我是 Vue2-cli 的项目,所以参考了下面的链接:

对于使用 Vue CLI 的项目,可以参考 Rsbuild - 从 Vue CLI 迁移

只是添加了一个 rsbuild.config.js 文件,还有添加了几个依赖包

在这里插入图片描述
我的 rsbuild.config.js 里主要配置了 pluginVue2 以及静态资源的 alias(路径别名)

什么是 alias :路径别名(alias)允许开发者为模块定义别名,以便于在代码中更方便的引用它们。当你想要使用一个简短、易于记忆的名称来代替冗长复杂的路径时,这将非常有用。

// rsbuild.config.js
import { defineConfig } from "@rsbuild/core";
import { pluginVue2 } from "@rsbuild/plugin-vue2";
import path from "path";export default defineConfig({html: {template: "./public/index.html",},plugins: [pluginVue2()],source: {// Specify the entry fileentry: {index: "./src/main.js",},alias: {"@": path.resolve(__dirname, "src"),"@assets": path.resolve(__dirname, "src/assets"),"/static": path.resolve(__dirname, "public/static"),},},output: {distPath: {root: 'build',js: 'resource/js',},},
});

新增的依赖也挺少的:

在这里插入图片描述


热更新

两者都还可以,一个0.1秒左右,一个 0.4秒左右

rsbuild 的热更新如下:
在这里插入图片描述

vue-cli-serve 热更新如下:

在这里插入图片描述

打包测试

同时打包:
请添加图片描述
感觉处理器资源会有抢夺,所以在试试分开打包:

vue-cli 的打包:
请添加图片描述
rsbuild 的打包:

请添加图片描述
速度大概是 8s vs 4.39s (只测了一轮)

体积是图片如下:
在这里插入图片描述

打包速度打包体积
Rsbuild4.39s7MB
Vue2-cli8s7.3MB

和之前的打包工具共存

因为是在尝鲜阶段,所以想着 vue-clirsbuild 共存,我测试了一下,当前组合是可以的

在这里插入图片描述

问题

Q1: 打包的时候报错: Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin’

 Cannot find module 'webpack/lib/rules/BasicEffectRulePlugin'

在这里插入图片描述
安装这个:

npm install vue-loader@latest

这篇关于新的打包工具 Rsbuild 尝鲜:Vue2-cli 项目迁移 Rsbuild的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1124005

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat