vite是如何实现依赖预构建的,浏览器为什么没有实现从node_modules查找依赖,vite开发环境解决了什么问题

浏览器的esmodule 为什么没有做从node_modules查找依赖项

浏览器是基于http请求的,node_modules中依赖项不可控,可能又会依赖很多的包,整个依赖图都需要加载的话很耗性能。 commonjs是运行在服务端的,以file形式读取文件,内部有规避机制。

依赖预构建

首先vite会找到对应的依赖,然后调用esbuild(对js语法进行处理的一个库),将其他规范的代码转换成esmodule规范,然后放到当前目录下的node_modules/.vite/deps【注: 缓存目录】,同时对esmodule规范的各个模块进行统一集成

node_modules三方包依赖图问题,将有依赖的包汇总导出到一个文件中。

解决了三个问题
  1. 不同的第三方包会有不同的导出格式(这个是vite没法约束人家的事情)
  2. 对路径的处理上可以直接使用.vite/deps,方便路径重写
  3. 网络多包传输的性能问题(也是原生esmodule规范不敢支持node_modules的原因之一)

有了依赖预构建以后无论他有多少的额外export 和import; vite都会尽可能的将他们进行集成最后只生成一个或者几个模块

思考题:webpack 能不能做vite这种冷启动优化?

个人觉得不太会做,一旦要改,那么将会动到大动脉。webpack支持多种模块化,commonJs, esmodule等

webpack的编译原理,AST抽象语法分析工具,分析出你写的js文件有哪些导入和导出操作,构建工具会监测你的代码文件,及时输出结果。冷启动时基于esmodule实现的。

因为webpack支持多种模块化,他一开始必须要统一模块化代码,所以意味着他需要将所有的依赖全部读一遍,

webpack更多关注兼容性,多端(可能是node), vite更多关注浏览器开发体验。

相关推荐
郭优秀的笔记9 分钟前
抽奖程序web程序
前端·css·css3
布兰妮甜32 分钟前
CSS Houdini 与 React 19 调度器:打造极致流畅的网页体验
前端·css·react.js·houdini
小小愿望1 小时前
ECharts 实战技巧:揭秘 X 轴末项标签 “莫名加粗” 之谜及破解之道
前端·echarts
小小愿望1 小时前
移动端浏览器中设置 100vh 却出现滚动条?
前端·javascript·css
fail_to_code1 小时前
请不要再只会回答宏任务和微任务了
前端
一大树1 小时前
Webpack 配置与优化全攻略:从基础到进阶实战
webpack
摸着石头过河的石头1 小时前
taro3.x-4.x路由拦截如何破?
前端·taro
lpfasd1231 小时前
开发Chrome/Edge插件基本流程
前端·chrome·edge
练习前端两年半2 小时前
🚀 Vue3 源码深度解析:Diff算法的五步优化策略与最长递增子序列的巧妙应用
前端·vue.js
烛阴2 小时前
TypeScript 接口入门:定义代码的契约与形态
前端·javascript·typescript