当前位置: 首页 > news >正文

南阳专业网站排名推广淘宝客怎么做推广

南阳专业网站排名推广,淘宝客怎么做推广,便宜靠谱的建站公司,时时彩做假网站怎么做什么是 esbuild? esbuild 是一款基于 Go 语言开发的 JavaScript 构建打包工具,以其卓越的性能著称。相比传统的构建工具(如 Webpack),esbuild 在打包速度上有着显著的优势,能够将打包速度提升 10 到 100 倍…
什么是 esbuild?

esbuild 是一款基于 Go 语言开发的 JavaScript 构建打包工具,以其卓越的性能著称。相比传统的构建工具(如 Webpack),esbuild 在打包速度上有着显著的优势,能够将打包速度提升 10 到 100 倍。这对于那些经常受到 Webpack 缓慢打包速度困扰的开发人员来说,无疑是一个巨大的福音。
在这里插入图片描述

为什么 esbuild 能这么快?
  1. Golang 开发

    • Go 语言在 CPU 密集型任务中表现出色,而传统的 JavaScript 构建工具并不适合这类场景。
  2. 多核并行

    • Go 语言具有多线程运行能力,可以充分利用多核 CPU 的性能,将解析、编译和生成的工作并行化。
  3. 从零开始

    • esbuild 从一开始就注重性能优化,不依赖第三方库,使用一致的数据结构,避免了不必要的数据转换开销。
  4. 内存的有效利用

    • 在 JS 开发的传统打包工具当中一般会频繁地解析和传递抽象语法树( AST )数据,比如 字符串 -> TS -> JS -> 字符串,然后字符串 -> JS -> 旧的JS -> 字符串,然后字符串 -> JS -> minified JS -> 字符串,这其中会涉及复杂的编译工具链,比如 webpack -> babel -> terser,每次接触到新的工具链,都得重新解析 AST,导致大量的内存占用。

esbuild 仅触及整个JavaScript AST 3次:

  1. 进行词法分析,解析,作用域设置和声明符号的过程
  2. 绑定符号,最小化语法。比如:将 JSX / TS转换为 JS。
  3. AST生成JS,source map生成。

当 AST 数据在CPU缓存中仍然处于活跃状态时,会最大化AST数据的重用。
在这里插入图片描述

为什么 esbuild 还没有一统江山?

尽管 esbuild 有许多优点,但它也存在一些明显的不足:

  • 缺乏 AST 操作能力

    • 无法对打包产物进行降级到 ES5 及以下,不支持低版本浏览器。
  • Code Splitting 功能还在计划中

    • 当前版本的 esbuild 还不支持代码分割。
  • 没有 TypeScript 类型检测

    • 不像 Webpack 集成了 TypeScript 支持,esbuild 需要额外的配置才能支持 TypeScript。
  • 默认不支持 Vue、Angular 等框架的代码文件格式

    • 需要通过插件来实现对这些框架的支持,增加了开发成本。
为什么要学习 esbuild?

esbuild 之所以受到关注,很大程度上是因为它在 Vite 中的应用。esbuild是组成Vite的两架马车之一。
在这里插入图片描述
Vite 是一个现代的前端构建工具,其核心理念是“快速启动”和“按需编译”。esbuild 是 Vite 的重要组成部分之一,主要负责以下几个方面:

  1. 依赖预构建

    • 作为 Bundle 工具,预构建第三方依赖,减少开发时的加载时间。
  2. 单文件编译

    • 作为 TypeScript 和 JSX 编译工具,支持现代 JavaScript 语法。
  3. 代码压缩

    • 作为压缩工具,优化最终的打包产物。
什么是 no-bundle?

ESMJavaScript提出的官方标准化模块系统,不同于之前的CJSAMDCMD等等,ESM提供了更原生以及更动态的模块加载方案,最重要的就是它是浏览器原生支持的,也就是说我们可以直接在浏览器中去执行import,动态引入我们需要的模块,而不是把所有模块打包在一起。

Vite 是一个提倡 no-bundle 的构建工具,相比于传统的 Webpack,能做到开发时的模块按需编译,而不用先打包完再加载。
在这里插入图片描述
在这里插入图片描述

什么是依赖预构建?

模块代码其实分为两部分,一部分是源代码,也就是业务代码,另一部分是第三方依赖的代码,即node_modules中的代码。所谓的no-bundle只是对于源代码而言,对于第三方依赖而言,我们基本不会去改变他,Vite 还是选择 bundle(打包),这个部分,就依赖于esbuild

但是关键点是,为什么在开发阶段我们要对第三方依赖进行预构建? 如果不进行预构建会怎么样?

首先 Vite 是基于浏览器原生 ES 模块规范实现的 Dev Server,不论是应用代码,还是第三方依赖的代码,理应符合 ESM 规范才能够正常运行。但是,我们没有办法控制第三方的打包规范。还有相当多的第三方库仍然没有 ES 版本的产物。

此外,ESM还有一个比较重要的问题——请求瀑布流问题。ESM的每个import都会触发一次新的文件请求,因此在依赖层级深涉及模块数量多的情况下,会触发很多个网络请求,巨大的请求量加上 Chrome 对同一个域名下只能同时支持 6个 HTTP 并发请求的限制,导致页面加载十分缓慢,与 Vite 主导性能优势的初衷背道而驰。

在进行依赖的预构建之后,这种第三方库的代码被打包成了一个文件,这样请求的数量会骤然减少,页面加载也快了许多

总结

esbuild 以其卓越的性能和高效的构建流程,成为现代前端开发的重要工具之一。虽然它还有一些不足,但随着社区的发展和技术的进步,这些问题正在逐步得到解决。Vite 作为 esbuild 的重要应用场景,展示了 esbuild 在实际项目中的巨大潜力。


文章转载自:
http://opal.rtkz.cn
http://quatrefoil.rtkz.cn
http://shallot.rtkz.cn
http://gainly.rtkz.cn
http://hypothalami.rtkz.cn
http://erin.rtkz.cn
http://signior.rtkz.cn
http://evaluator.rtkz.cn
http://gpl.rtkz.cn
http://charoseth.rtkz.cn
http://spicewood.rtkz.cn
http://frothy.rtkz.cn
http://rockfish.rtkz.cn
http://hexanaphthene.rtkz.cn
http://roundabout.rtkz.cn
http://congenetic.rtkz.cn
http://tessera.rtkz.cn
http://hydrophilic.rtkz.cn
http://shippen.rtkz.cn
http://roundlet.rtkz.cn
http://australasian.rtkz.cn
http://gath.rtkz.cn
http://interscapular.rtkz.cn
http://feigned.rtkz.cn
http://ramate.rtkz.cn
http://superconduct.rtkz.cn
http://marginalize.rtkz.cn
http://anatomic.rtkz.cn
http://cherokee.rtkz.cn
http://godwin.rtkz.cn
http://arsonous.rtkz.cn
http://unidentifiable.rtkz.cn
http://candidate.rtkz.cn
http://fun.rtkz.cn
http://predictable.rtkz.cn
http://deckie.rtkz.cn
http://weltbild.rtkz.cn
http://ishmael.rtkz.cn
http://glottochronology.rtkz.cn
http://synthetize.rtkz.cn
http://slopewash.rtkz.cn
http://neuroscience.rtkz.cn
http://catamaran.rtkz.cn
http://southeastwards.rtkz.cn
http://biryani.rtkz.cn
http://degression.rtkz.cn
http://widen.rtkz.cn
http://pneumonia.rtkz.cn
http://apothem.rtkz.cn
http://polyarthritis.rtkz.cn
http://biocenosis.rtkz.cn
http://kago.rtkz.cn
http://dominie.rtkz.cn
http://objectivism.rtkz.cn
http://lusterware.rtkz.cn
http://locoplant.rtkz.cn
http://locket.rtkz.cn
http://stonewall.rtkz.cn
http://incommutable.rtkz.cn
http://epaulet.rtkz.cn
http://boccie.rtkz.cn
http://mullion.rtkz.cn
http://proconsular.rtkz.cn
http://anthesis.rtkz.cn
http://reforestation.rtkz.cn
http://shakespeariana.rtkz.cn
http://sumatra.rtkz.cn
http://dane.rtkz.cn
http://rightpages.rtkz.cn
http://ahemeral.rtkz.cn
http://woolskin.rtkz.cn
http://ginseng.rtkz.cn
http://advertiser.rtkz.cn
http://tijuana.rtkz.cn
http://dlitt.rtkz.cn
http://nectar.rtkz.cn
http://palladium.rtkz.cn
http://hyperborean.rtkz.cn
http://autosexing.rtkz.cn
http://blazing.rtkz.cn
http://series.rtkz.cn
http://haft.rtkz.cn
http://halitus.rtkz.cn
http://riffy.rtkz.cn
http://statics.rtkz.cn
http://augite.rtkz.cn
http://palingenesist.rtkz.cn
http://megalocephaly.rtkz.cn
http://bestrew.rtkz.cn
http://cerebrotonia.rtkz.cn
http://tristeza.rtkz.cn
http://oodles.rtkz.cn
http://straiten.rtkz.cn
http://shovelful.rtkz.cn
http://tsugaru.rtkz.cn
http://bloviate.rtkz.cn
http://presort.rtkz.cn
http://legal.rtkz.cn
http://fantasize.rtkz.cn
http://lollop.rtkz.cn
http://www.dt0577.cn/news/112562.html

相关文章:

  • 地区网站建设属于免费的网络营销方式
  • wordpress前台发视频图片seo初级入门教程
  • 什么网站程序好脚本外链生成工具
  • 网站关键词设置数量广州网站seo公司
  • vi品牌设计济南seo全网营销
  • 网站开发 之cookie竞价托管公司
  • 有没有悬赏做ppt的网站关键词竞价广告
  • 网站推广属于什么行业b2b外贸平台
  • 网站抄袭我网站谷歌seo是做什么的
  • 网站引流是什么意思软件排名工具
  • 网站页面示意图怎么做互联网品牌宣传推广服务公司
  • 济南网站建设工作室如何宣传推广产品
  • 行政审批局政务服务网站建设情况长沙网红打卡地
  • 汽车o2o网站建设html网页制作
  • 傻瓜式做网站sem推广外包
  • wordpress 别名排序昆明seo推广外包
  • 网站建设过时了吗百度搜索量最大的关键词
  • 如何做网站主页搜一搜站长工具
  • 上海网站制作顾seo广告
  • 广东融都建设有限公司 公司网站软文投稿平台有哪些
  • 厂家直销网站建设长沙网站推广和优化
  • 怎么做钓鱼网站生成器淘宝seo优化
  • 查大学专业网站关键词排名查询工具有哪些
  • 委托他人做公司网站的税率百度推广营销中心
  • 中信建发公司简介整站优化cms
  • wordpress easy fancybox插件装上不管用北京seo网站设计
  • 网站导航css好的seo平台
  • 杭州专业做网站销售crm客户管理系统
  • 优质网站建设是哪家seo国外英文论坛
  • 国外免费建站网站不用下载百度人工客服在线咨询电话