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考虑的是浏览器端的资源文件加载

相关推荐
天蓝色的鱼鱼1 天前
都2026年了还不会Vite插件开发?手写一个版本管理插件,5分钟包会!
前端·vite
codingWhat5 天前
前端组件库开发实践:从零到发布
前端·npm·vite
小岛前端6 天前
Cloudflare 掀桌子了,Next.js 迎来重大变化,尤雨溪都说酷!
前端·vite·next.js
Java陈序员7 天前
太香了!一款轻量级的 Elasticsearch 可视化管理工具!
vue.js·elasticsearch·vite
天蓝色的鱼鱼9 天前
Vite 8:从“混动”到“纯电”,构建性能提升10倍+
前端·vite
Roc.Chang13 天前
Vite 启动报错:listen EACCES: permission denied 0.0.0.0:80 解决方案
linux·前端·vue·vite
问道飞鱼19 天前
【前端知识】Vite用法从入门到实战
前端·vite·项目构建
weixin_425543731 个月前
TRAE CN3.3.25 构建的Electron简易DEMO应用
前端·typescript·electron·vite·nestjs
敲敲了个代码1 个月前
从N倍人力到1次修改:Vite Plugin Modular 如何拯救多产品前端维护困境
前端·javascript·面试·职场和发展·typescript·vite
打小就很皮...1 个月前
React 19 + Vite 6 + SWC 构建优化实践
前端·react.js·vite·swc