Vite 学习笔记(二):Vite相对于Webpack的优势与Vite脚手架

webpack的工作流程

webpack构建项目会根据资源模块的依赖关系构建依赖图,根据依赖图去加载/处理各种文件。

而当我们的项目越来越大的时候,需要处理的JavaScript代码量也呈指数级增长。包含数千个模块的大型项目相当普遍。基于JavaScript开发的工具就会开始遇到性能瓶颈:通常需要很长时间(甚至是几分钟!)才能启动开发服务器,即使使用模块热替换(HMR),文件修改后的效果也需要几秒钟才能在浏览器中反映出来。此时 webpack 构建项目时的构建速度服务器的启动就会非常慢。

因为webpack为了支持多种模块化进行了统一的模块化处理。(webpack考虑的是兼容性的问题(浏览器端 + 服务端)

webpack 构建流程的示意图如下:

Vite 为什么比 webpack 快

首先我们要明白webpack应该是为了兼容性的考虑,所以webpack支持多种模块化,但是vite只是支持ESM规范,所以此时不需要去遍历依赖图文件了,进而问题就得到了解决

Vite 工作示意图如下:

webpack需要把所有的文件、依赖文件统统打包成Bundle之后,才会去启动Server,而vite一开始就启动Server,然后按需加载各种文件的。

所以基于这种特性,Vite 相较于 webpack 来说会更快

create-vite、vite、create-vue之间的区别

create-vitecreate-vue本身都是创建了一个快捷工程化项目,我们称之为clicreate-vite能够提供React等框架的模板,create-vue只是针对于vue3所存在的一个cli,他们都是基于vite来创建服务器、打包的。

总结

vite能够跟webpack一样,能够实现资源模块的打包加载,但是vite相比于webpack确实轻量了不少,他解决了webpack遍历依赖文件的问题,换句话说webpack考虑的是兼容性的问题(浏览器端 + 服务端),而vite考虑的是浏览器端的资源文件加载

相关推荐
charlee442 天前
从后端获取数据传输到前端进行显示(cpp-httplib+Vditor+Handlebars)
vite·前后端分离·vditor·cpp-httplib·handlebars
imkaifan2 天前
vite的插件 legacy--兼容低版本的浏览器
vue3·vite
南望无一4 天前
Vite拆包后Chunk级别的循环依赖分析及解决方案
前端·vite
Tzarevich6 天前
现代前端开发工程化:从 Vite 到 Vue 3 多页面应用实战
vue.js·vite
韭菜炒大葱7 天前
现代前端开发工程化:Vue3 + Vite 带你从 0 到 1 搭建 Vue3 项目🚀
前端·vue.js·vite
蜗牛攻城狮8 天前
Vite 项目中 `node_modules/.vite/deps` 文件夹详解
前端·vite·构建工具
白哥学前端9 天前
Vite Proxy到底是咋个工作嘞?
axios·vite
Bigger10 天前
后端拒写接口?前端硬核自救:纯前端实现静态资源下载全链路解析
前端·浏览器·vite
San3010 天前
现代前端工程化实战:从 Vite 到 React Router demo的构建之旅
react.js·前端框架·vite