构建工具知识储备

webpack和vite工程化的区别

解答思路一:

1. 两个都是构建工具,主要做的就是集成的工作,比如:支持模块化开发、处理代码兼容性(ts、less、scss等语法转换)、提高项目性能(压缩文件、代码分割)、优化项目开发体验(hmr热更新、开发服务器解决跨域的问题)可以让我们不用关心生产的代码,也不用关心代码在浏览器是怎么运行的,主要开发时写的爽就行。

2. webpack和vite最根本的区别是由于

        webpack支持多种模块化开发,所以他在运行之前需要分析依赖,即根据AST语法分析工具分析导入导出语句,将多种模块化语句转化为浏览器可以识别的代码。所以js代码多的时候很长时间才能打开开发服务器,热更新时由于依赖的文件也需要重新编译,需要的时间可能长达几秒钟

        vite则是基于es module开发的。当代浏览器天然支持es module。所以vite可以直接打开一个开发服务器,请求到哪个页面再进行编译。所以启动开发服务器速度特别快,同时如果改动了某个模块,仅需要浏览器重新请求该模块即可,热更新很快

解答思路二:

1. 打包编译的区别(开发环境)

     webpack会先打包,然后启动开发服务器,请求服务器时直接给予打包结果。

     vite则是直接启动开发服务器,请求哪个模块再对哪个模块进行实时编译。

2. 底层原理

        webpack基于nodejs构建,以毫秒计数;vite基于esbuild预构建依赖,esbuild是用go语言编写的,以纳秒计数

        由于现代浏览器本身就支持EsModule,会自动向依赖的Module发出请求。vite利用这一点,将开发环境下的模块文件,作为浏览器要执行的文件,而不是像webpack那样进行打包合并。由于vite启动时不需要打包,也就意味着不需要分析模块的依赖,不需要编译,因此启动速度非常快。

        当浏览器请求某个模块时,再根据需要对模块内容进行编译。这种按需动态编译的方式,极大的缩减了编译时间,项目越复杂,模块越多,vite的优势越明显。

        由于vite使用esmodule。所以代码中不可以使用commonjs

3. hmr热更新方面

        vite改动了一个模块后,仅需要让浏览器重新请求该模块即可

        webpack则需要将该模块的相关依赖模块全部编译一遍

4. 打包到生产环境时

        vite使用传统的rollup进行打包,因此。vite的主要优势在开发阶段

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值