广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vite使用Esbuild提升性能详解
  • 951
分享到

Vite使用Esbuild提升性能详解

ViteEsbuild性能提升ViteEsbuild 2022-11-13 14:11:13 951人浏览 安东尼
摘要

目录前言初探 Esbuild关键 api - transfrom & buildpluginEsbuild 在 Vite 中的巧妙使用预构建middlewares 中内容转换

前言

在上一篇 为什么有人说 vite 快,有人却说 vite 慢? 中,我们提到过开发模式下使用 Vite 会有首屏性能下降的负面效果。之所以会造成首屏性能下降,一方面是 dev server 需要完成预构建才可以响应首屏请求;另一方面是需要对请求文件做实时转换。

也许有的同学会问,是不是针对这两个方面做优化,就可以提升首屏性能呢?原则上这样是没有问题的,而且 Vite 也是这么做的。为了能提升性能,Vite 另辟蹊径的借助了 Esbuild 能快速完成项目打包、文件转换的能力来进行预构建、内容转换,效果非常好。

今天小编就通过本文和大家一起聊一聊 Vite 是怎样利用 Esbuild 来提升性能的。

初探 Esbuild

首先,小编先带大家简单了解一下 Esbuild,其官方地址是: Esbuild。

什么是 Esbuild

Esbuild 是一款基于 Go 语言开发的 javascript 打包工具,最大的一个特征就是快。

通过官网提供的一张图,我们可以清晰的看到 Esbuild 的表现是多么优秀:

同样规模的项目,使用 Esbuild 可以将打包速度提升 10 - 100 倍,这对广大一直饱受 webpack 缓慢打包速度折磨的开发人员来说,简直就是福音。

Esbuild 之所以能这么快,主要原因有两个:

  • Go 语言开发,可以多线程打包,代码直接编译成机器码;
  • WEBpack 一直被人诟病构建速度慢,主要原因是在打包构建过程中,存在大量的 resolveloadtransfORMparse 操作(详见 为什么有人说 vite 快,有人却说 vite 慢?- 快速的冷启动 ),而这些操作通常是通过 javascript 代码来执行的。要知道,javascript 并不是什么高效的语言,在执行过程中要先编译后执行,还是单线程并且不能利用多核 cpu 优势,和 Go 语言相比,效率很低。
  • 可充分利用多核 cpu 优势;

关键 API - transfrom & build

Esbuild 并不复杂。它对外提供了两个 API - transformbuild,使用起来非常简单。

transfrom,转换的意思。通过这个 api,我们可以将 tsjsxtsx 等格式的内容转化为 jstransfrom 只负责文件内容转换,并不会生成一个新的文件。

build,构建的意思,根据指定的单个或者多个入口,分析依赖,并使用 loader 将不同格式的内容转化为 js 内容,生成一个或多个 bundle 文件。

这两个 API 的使用方式:

const res = await esbuild.transform(code, options) // 将 code 转换为指定格式的内容
esbuild.build(options) // 打包构建

关于使用 transformbuild 需要传入的具体配置项,本文就不详细说明了,官网对这一块儿有很详细的说明,感兴趣的同学可以去官网 - simple-options、Advanced options 看看,也可以自己动手试试。

plugin

WebpackRollup 等构建工具一样,Esbuild 也提供了供外部使用的 plugin,使得我们可以介入构建打包过程。

在这里要说明一点,只有 build 这个 API 的入参中可以配置 plugintransform 不可以。

一个标准的 plugin 的标准格式如下:

let customerPlugin = {
    name: 'xxx',
    setup: (build) => {
        build.onResolve({ filter: '', namespace: '' }, args => { ...});
        build.onLoad({ filter: '', namespace: ''}, args => { ... });
        build.onStart(() => { ... });
        build.onEnd((result) => { ... });
    }
}

其中,setup 可以帮助我们在 build 的各个过程中注册 hook

Esbuild 对外提供的 hook 比较简单,总共 4 个:

  • onResolve, 解析 url 时触发,可自定义 url 如何解析。如果 callback 有返回 path,后面的同类型 callback 将不会执行。所有的 onResolve callback 将按照对应的 plugin 注册的顺序执行。
  • onLoad, 加载模块时触发,可自定义模块如何加载。 如果 callback 有返回 contents,后面的同类型 callback 将不会执行。所有的 onLoad callback 将按照对应的 plugin 注册的顺序执行。
  • onStart, 每次 build 开始时都会触发,没有入参,因此不具有改变 build 的能力。多个 pluginonStart 并行执行。
  • onEnd, 每次 build 结束时会触发,入参为 build 的结果,可对 result 做修改。所有的的 onEnd 将按照对应的 plugin 注册的顺序执行。

正是有了 onResolveonLoadonStartonEnd,我们可以在 build 过程中的解析 url、加载模块内容、构建开始、构建结束阶段介入,做自定义操作。

Esbuild 在 Vite 中的巧妙使用

了解了 Esbuild 的基本用法以后,小编就带大家一起来看看 Vite 是怎么利用 Esbuild 来做预构建和内容转换的。

预构建

先来回顾一下为什么要做预构建。

原因有两点:

  • 将非 ESM 规范的代码转换为符合 ESM 规范的代码;
  • 将第三方依赖内部的多个文件合并为一个,减少 Http 请求数量;

要完成预构建,最关键的两点是找到项目中所有的第三份依赖和对第三方依赖做合并、转换。借助 EsbuildVite 很轻松的实现了这两个诉求。

寻找第三方依赖

寻找第三方依赖的过程非常简单,分为两步:

定义一个带 onResolve hookonLoad hookesbuild plugin

执行 esbuildbuild 方法做打包构建;

WebpackRollupParcel 等构建工具一样,Esbuild 在做打包构建时也要构建模块依赖图 - module graph(具体过程可参考 为什么有人说 vite 快,有人却说 vite 慢?- 快速的冷启动 中 Webpack 构建 module graph)。

在构建 module graph 时,第一步就是解析模块的绝对路径,这个时候就会触发 onResolve hook。在 onResolve hook 触发时,会传入模块的路径。根据模块的路径,我们就可以判断出这个模块是第三方依赖还是业务代码。

举个 ?,

// main.tsx
import React from 'react';
import CustomeComponent from './components/CustomeComponent';
...

在对 main.tsx 的内容做 parser 操作时,能知道 main.tsx 依赖 reactCustomeComponent,然后开始解析 reactCustomeComponent

解析 reactCustomeComponent 时,会触发 onResolve hook,入参分别为 'react' 和 './components/CustomeComponent'。

根据入参,我们可以很清楚的区分 'react' 是第三方依赖,'./components/CustomeComponet' 是业务代码。

这样,esbuild 完成构建,项目中的第三方依赖也就收集完毕了。所有的第三方依赖会收集到一个 deps 列表中。

  • 合并、转换第三方依赖
  • 知道了项目中的第三方依赖以后,再做合并、转换操作就非常简单了。
  • 这一步, Vite 直接通过 esbuild 提供的 build 方法,指定 entryPoints 为收集到的第三方依赖,formatesm,再做一次打包构建。
  • 这一次,会对第三方依赖做合并、转换操作。打包构建完成以后,再把构建内容输出到 /node_modules/.vite/deps 下。

这样,通过两次 esbuild.build,预构建就完成了。

middlewares 中内容转换

Vite 中源文件的转换是在 dev server 启动以后通过 middlewares 实现的。

当浏览器发起请求以后,dev sever 会通过相应的 middlewares 对请求做处理,然后将处理以后的内容返回给浏览器。

middlewares 对源文件的处理,分为 resolveloadtransformparser 四个过程:

  • resolve - 解析 url,找到源文件的绝对路径;
  • load - 加载源文件。如果是第三方依赖,直接将预构建内容返回给浏览器;如果是业务代码,继续 transformparser
  • transfrom - 对源文件内容做转换,即 ts -> js, less -> CSS 等。转换完成的内容可以直接返回给浏览器了。
  • parser - 对转换以后的内容做分析,找到依赖模块,对依赖模块做预转换 - pre transform 操作,即重复 1 - 4
  • pre transformVite 做的一个优化点。预转换的内容会先做缓存,等浏览器发起请求以后,如果已经完成转换,直接将缓存的内容返回给浏览器。

Vite 在处理步骤 3 时,是通过 esbuild.transform 实现的,对比 Webpack 使用各个 loader 处理源文件,那是非常简单、快捷的。

结束语

有一说一,Vite 通过 Esbuild 来优化预构建和内容转换的思路非常棒,这给我们以后处理同类问题提供了解决方案,真心给尤大点 ??。

另外除了使用 EsbuildVite 内部还有很多可以拿出来单独讲的优化技巧,这个以后有机会小编可以再给大家详细讲讲。

以上就是Vite使用Esbuild提升性能详解的详细内容,更多关于Vite Esbuild性能提升的资料请关注编程网其它相关文章!

--结束END--

本文标题: Vite使用Esbuild提升性能详解

本文链接: https://www.lsjlt.com/news/172278.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Vite使用Esbuild提升性能详解
    目录前言初探 Esbuild关键 API - transfrom & buildpluginEsbuild 在 Vite 中的巧妙使用预构建middlewares 中内容转换...
    99+
    2022-11-13
    Vite Esbuild性能提升 Vite Esbuild
  • 详解盒子端CSS动画性能提升
    目录流畅动画的标准盒子端动画优化动画性能上报分析研究结论Web 每一帧的渲染优化动画步骤1.精简 DOM ,合理布局2.使用 transform 代替 left、top,减少使用耗性...
    99+
    2022-11-12
  • Redis性能大幅提升之Batch批量读写详解
    前言 本文主要介绍的是关于Redis性能提升之Batch批量读写的相关内容,分享出来供大家参考学习,下面来看看详细的介绍: 提示:本文针对的是StackExchange.Redis 一、问题呈现 前段时间在...
    99+
    2022-06-04
    批量 详解 大幅
  • 详解PHP7开启OPcache和Swoole性能的提升对比
    目录前期准备不开启opcache和laravel开启OPcache使用swoole加速包总结前期准备 测试所用的主机为虚拟机,虚拟机配置在双核4GB的个人电脑中。虚拟机系统为linu...
    99+
    2022-11-12
  • 详解redis大幅性能提升之使用管道(PipeLine)和批量(Batch)操作
    前段时间在做用户画像的时候,遇到了这样的一个问题,记录某一个商品的用户购买群,刚好这种需求就可以用到Redis中的Set,key作为productID,value就是具体的customerid集合,后续的话...
    99+
    2022-06-04
    批量 详解 管道
  • 如何使用JavaScript的Map提升性能
    这篇文章将为大家详细讲解有关如何使用JavaScript的Map提升性能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Map与常规对象有什么不同Map和常规对象主要有2个...
    99+
    2022-10-19
  • 如何使用OPCache提升PHP的性能
    目录什么是 OPcache安装 Opcacheab 测试效果配置参考总结参考文档对于 PHP 这样的解释型语言来说,每次的运行都会将所有的代码进行一次加载解析,这样一方面的好处是代码...
    99+
    2022-11-12
  • 使用PhpFastCache提升您的网站性能
    在本文中,我们将探索PhpFastCache库,该库使您可以在PHP应用程序中实现缓存。 因此,它有助于改善整体网站性能和页面加载时间。什么是PhpFastCache?PhpFastCache是一个库,可轻松在PHP应用程序中实现缓存。 这...
    99+
    2023-03-17
    PhpFastCache php
  • 怎么使用OPCache提升PHP的性能
    这篇文章给大家分享的是有关怎么使用OPCache提升PHP的性能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。PHP开发环境搭建工具有哪些一、phpStudy,是一个新手入门最常用的开发环境。二、WampServ...
    99+
    2023-06-14
  • 如何使用C++的StringBuilder提升性能
    今天就跟大家聊聊有关如何使用C++的StringBuilder提升性能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。介绍经常出现客户端打电话抱怨说:你们的程序慢如蜗牛。你开始检查可能...
    99+
    2023-06-17
  • 详解PostgreSQL提升批量数据导入性能的n种方法
    关键字:批量数据导入,数据加载,大量插入,加快,提升速度 多元化选择时代,人生里很多事物都是如此,凡事都没有一成不变的方式和方法。不管白猫黑猫,能抓老鼠的就是好猫,适合自己的就是最好...
    99+
    2022-11-11
  • .NET使用Collections.Pooled提升性能优化的方法
    目录简介Collections.Pooled如何使用性能对比PooledList<T>PooledDictionary<TKey, TValue>Pooled...
    99+
    2022-11-13
  • 详解Spring Boot使用系统参数表提升系统的灵活性
    目录一、使用系统参数表的好处二、系统参数表的表结构三、系统参数表在项目中的使用3.1、Entity类3.2、Dao类3.3、Service类3.4、ServiceImpl类3.5、全...
    99+
    2022-11-12
  • ASP 容器的使用是否能提升 Laravel 应用的性能?
    Laravel 是一个广受欢迎的 PHP Web 框架,它提供了许多强大的功能和工具,使得 Web 应用的开发变得更加容易和高效。然而,随着 Laravel 应用规模的增大,性能问题也逐渐浮现。为了解决这个问题,很多开发者开始研究使用 A...
    99+
    2023-09-30
    容器 关键字 laravel
  • 使用MySQL MVCC 提升数据库性能的技巧
    使用MySQL MVCC 提升数据库性能的技巧随着互联网的发展,数据库成为了系统架构中不可或缺的一部分。MySQL作为最常用的关系型数据库之一,广泛应用于各种网站和应用程序中。为了提高数据库的性能和可扩展性,MySQL引入了MVCC(多版本...
    99+
    2023-10-22
    MySQL mvcc 数据库性能提升
  • 怎么使用ABAP异步RFC调用提升应用性能
    本篇内容介绍了“怎么使用ABAP异步RFC调用提升应用性能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!采用如下report 研究async...
    99+
    2023-06-04
  • 如何使用Memcache提升PHP应用程序的性能和可用性?
    如何使用Memcache提升PHP应用程序的性能和可用性?引言:随着互联网应用程序的迅速发展和用户访问量的增加,提高应用程序的性能和可用性成为了开发者亟需解决的问题之一。其中,使用缓存是一种常见的优化手段。Memcache是一种常用的缓存技...
    99+
    2023-11-09
    PHP应用程序 Memcache(缓存) 性能和可用性
  • PHP8中如何使用JIT编译提升代码性能?
    PHP语言一直以来都被广泛用于构建Web应用程序,但是由于解释执行的特性,导致了其性能相对较低。为了提升PHP的性能,从PHP7开始引入了JIT(Just-in-Time)编译器,而在全新的PHP8版本中,JIT编译的功能得到了进一步的改进...
    99+
    2023-10-22
    PHP JIT编译 代码性能
  • 如何使用php函数来提升程序的性能?
    在开发Web应用程序时,性能是一个非常重要的因素。用户期望获得快速的响应和高效的操作体验。PHP是一种流行的服务器端开发语言,它提供了许多内置函数来完成各种任务。在编写PHP代码时,合理地使用这些函数可以显着提升程序的性能。本文将介绍一些常...
    99+
    2023-10-21
    缓存 (Cache) 多线程 (Multithreading) 优化 (Optimize)
  • 利用JuiceFS使MySQL 备份验证性能提升 10 倍
    目录数据准备使用默认参数增大XtraBackup的内存缓冲区增大XtraBackup读线程数JuiceFS启用异步写增大JuiceFS的磁盘缓存增大数据库数据量总结前言: Juice...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作