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更多关注浏览器开发体验。

相关推荐
前端 贾公子12 分钟前
从入门到实践:前端 Monorepo 工程化实战(4)
前端
菩提小狗15 分钟前
Sqlmap双击运行脚本,双击直接打开。
前端·笔记·安全·web安全
前端工作日常26 分钟前
我学习到的AG-UI的概念
前端
韩师傅31 分钟前
前端开发消亡史:AI也无法掩盖没有设计创造力的真相
前端·人工智能·后端
XiaoYu20021 小时前
第12章 支付宝SDK
前端
双向331 小时前
RAG的下一站:检索增强生成如何重塑企业知识中枢?
前端
拖拉斯旋风1 小时前
从零开始:使用 Ollama 在本地部署开源大模型并集成到 React 应用
前端·javascript·ollama
asing1 小时前
🤯 为什么我的收银台在鸿蒙系统“第一次返回”死活拦不住?一次差点背锅的排查实录
前端·harmonyos
德育处主任1 小时前
『NAS』在群晖部署图片压缩工具-Squoosh
前端·javascript·docker
Hao_Harrision1 小时前
50天50个小项目 (React19 + Tailwindcss V4) ✨| ThreeDBackgroundBoxes(3D背景盒子组件)
前端·3d·typescript·react·tailwindcss·vite7