vite对比webpack

vite和webpack的主要区别在开发阶段

webpack

开发阶段运行项目的时候需要执行webpack打包命令,就是将项目打包一次,打包完后把项目放入开发服务器中然后启动开发服务器,请求服务器是直接给予打包结果。

这些过程在vue的开发过程运行项目时的打包其实是在内存中完成的,所以经过这一系列的方式会

使得在开发阶段每次修改代码都会运行打包,如果依赖太多运行就会很慢

vite

相对于webpack,在开发阶段vite效率要高很多。vite的原理是

1、vite在开发阶段没有打包过程,他是直接启动一个服务器,启动后就啥事也没有做

2、请求一个模块到开发服务器;

3、开发服务器编译模块,根据页面用所需要的依赖去加载文件

4、加载完成后,开发服务器把编译的结果返回给页面

vite的优势

1、vite是直接启动开发服务器,请求那个模块再对该模块进行实时编译。由于现代浏览器本身就支持ES Moudule,会自动向依赖的Module发出请求。

2、vite成分利用这一点,将开发环境下的模块文件,就作为浏览器要执行的文件,而不是像webpack那样进行打包合并。

3、由于vite在启动的时候不需要打包,也就意味着不需要分析模块的依赖,不需要编译,因此启动速度非常块

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

4、在HMR方面,当改动一个模块后,仅需让浏览器重新请求该模块即可,不像webpack那样需要把该模块的

相关依赖模块全部编译一次,效率更高

当需要打包到生产环境时,vite使用传统的rollup进行打包,因此,vite的主要优势在开发阶段。另外,由于vite利用的时ES Module,因此在代码中不可以使用CommonJS

你可能感兴趣的:(vite对比webpack)