新的打包工具 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

相关文章

基于Python编写一个git自动上传的脚本(打包成exe)

《基于Python编写一个git自动上传的脚本(打包成exe)》这篇文章主要为大家详细介绍了如何基于Python编写一个git自动上传的脚本并打包成exe,文中的示例代码讲解详细,感兴趣的小伙伴可以跟... 目录前言效果如下源码实现利用pyinstaller打包成exe利用ResourceHacker修改e

Django调用外部Python程序的完整项目实战

《Django调用外部Python程序的完整项目实战》Django是一个强大的PythonWeb框架,它的设计理念简洁优雅,:本文主要介绍Django调用外部Python程序的完整项目实战,文中通... 目录一、为什么 Django 需要调用外部 python 程序二、三种常见的调用方式方式 1:直接 im

python版本切换工具pyenv的安装及用法

《python版本切换工具pyenv的安装及用法》Pyenv是管理Python版本的最佳工具之一,特别适合开发者和需要切换多个Python版本的用户,:本文主要介绍python版本切换工具pyen... 目录Pyenv 是什么?安装 Pyenv(MACOS)使用 Homebrew:配置 shell(zsh

MySQL数据目录迁移的完整过程

《MySQL数据目录迁移的完整过程》文章详细介绍了将MySQL数据目录迁移到新硬盘的整个过程,包括新硬盘挂载、创建新的数据目录、迁移数据(推荐使用两遍rsync方案)、修改MySQL配置文件和重启验证... 目录1,新硬盘挂载(如果有的话)2,创建新的 mysql 数据目录3,迁移 MySQL 数据(推荐两

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

解决idea启动项目报错java: OutOfMemoryError: insufficient memory

《解决idea启动项目报错java:OutOfMemoryError:insufficientmemory》:本文主要介绍解决idea启动项目报错java:OutOfMemoryError... 目录原因:解决:总结 原因:在Java中遇到OutOfMemoryError: insufficient me

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流

python项目环境切换的几种实现方式

《python项目环境切换的几种实现方式》本文主要介绍了python项目环境切换的几种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 如何在不同python项目中,安装不同的依赖2. 如何切换到不同项目的工作空间3.创建项目