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

相关推荐
zhengxianyi5152 天前
vite build 发布到nginx二级目录——将yudao-ui-go-view打包、部署到big目录下
vue.js·nginx·vite·前后端分离·打包·ruoyi-vue-pro优化·部署运维
Mast Sail2 天前
WebStrom+Vitesse+Vue3项目路径报错爆红问题
vue·vite·webstorm
华玥作者3 天前
uni-app + Vite 项目中使用 @uni-helper/vite-plugin-uni-pages 实现自动路由配置(超详细)
前端·uni-app·vue·vue3·vite
coderjc13 天前
依赖预构建
vite
实习生小黄14 天前
vue3静态文件打包404解决方案
前端·vue.js·vite
Awu122715 天前
⚡全局自动化:我用Vite插件为所有CRUD组件一键添加指令
前端·vite·前端工程化
wetyuo16 天前
【随手记】uniapp + V3 使用TailwindCss3
uni-app·vue·css3·vite
止观止19 天前
告别全局污染:深入理解 ES Modules 模块化与构建工具
javascript·webpack·vite·前端工程化·es modules
charlee4423 天前
从后端获取数据传输到前端进行显示(cpp-httplib+Vditor+Handlebars)
vite·前后端分离·vditor·cpp-httplib·handlebars