vite源码学习

源码地址,目前版本是

image.png

核心目录主要是vite\packages下的几个包
image.png

image.png

vite 支持的配置

配置 Vite | Vite 官方中文文档 (vitejs.dev)

启动

image.png

image.png

image.png

dev

首先是sever文件下的createServer,先试整合配置文件vite.config.js 和 命令行里的配置到config中并对解析插件并排序。


image.png

image.png

先处理httpserver的相关配置然后启动一个http(s)server,并升级为websocket


image.png

image.png

使用 chokidar监听文件变化(这是进行热更新的基础)


image.png

常见配置项
  • persistent:bollean,与原生fs.watch一样,表示是否保护进程不退出持久监听,默认值为true
  • ignored:string,所要忽略监听的文件或者文件夹
  • ignoreInitial:bollean,表示是否对增加文件或者增加文件夹的时候进行发送事件,默认值为false表示add/addDir会触发事件
  • cwd:string类型,没有默认值,类似于appBasepath,监听的paths所相对的路径。
  • usePolling:bollean,表示是否使用前面提到的fs.watchFile()进行轮询操作,由于轮询会导致cpu飙升,所以此选项通常在需要通过网络监视文件的时候才设置为true即使用fs.watchFile(),默认值为false
  • depth:number类型,没有默认值,如果设定则表示限定了会递归监听多少个子目录。
  • ignorePermissionErrors,忽略权限错误。
  • disableGlobbing,如果为 true,所有 globs都被视为字面路径名称,即使它们具有特殊字符。

根据container生成moduleGraph,然后将所有的plugin统一进行处理,保存到container中。


image.png

moduleGraph主要是将传入的插件容器container挂载到this上,并初始化 4 个属性urlToModuleMap、idToModuleMap、fileToModulesMap、safeModulesPath,Vite 为每个模块创建一个ModuleNode对象,对象内包含模块间的引用关系以及模块信息。模块信息包含绝对路径、转换后的代码、接收的热更新模块等。


image.png
  • resolveUrl,调用所有插件的resolveId钩子函数,根据当前被请求模块的url,获取该文件的绝对路径,最后返回[url, 文件绝对路径]。
  • ensureEntryFromUrl,根据模块路径创建ModuleNode对象,将对象收集到ModuleGraph的属性中;最后返回这个对象。


    image.png
  • onFileChange,根据传入的file获取并清空对应ModuleNode对象的transformResult属性值。
  • updateModuleInfo,用于构建和更新模块之间的引用关系。

初始化后面要返回的vite-dev-server,绑定了一些属性和方法

image.png

没怎么看懂推荐一下这篇博客vite中的vue-dev-server

watcher发生变化的时候,进行相应的热更新处理


image.png

执行vite 钩子 configureServer,这里postHooks只收集有configureServer的plugin


image.png

中间件的使用


image.png
  • baseMiddleware,用来处理配置项中的 base 选项(开发或生产环境服务的公共基础路径)。我们的代码在部署到生产环境时,一般会部署到某一个特定的目录下,这时访问请求的 url 会带上这个特定目录的前缀,也就是这里的 base 选项。baseMiddleware 会删除 base 前缀。
  • servePublicMiddleware,响应 public 文件夹下的请求。vite 默认会将 public 文件夹下的文件当作项目根目录下的文件,且不做任何转义处理。
  • transformMiddleware,用来转义处理 js、ts、css、png 等资源文件,这是 vite 最核心的代码实现。在这个中间件中会执行 resolveId、load、transform 这三个钩子函数。如果我们想对代码做些什么,可以通过写插件的方式实现这三个钩子。
  • serveStaticMiddleware,用来响应不需要转义的的资源文件请求,比如页面中的 img 标签发出的图片请求。
  • indexHtmlMiddleware,用来处理 html 文件请求。

执行posHooks里的plugins


image.png

几个重要的插件:

  • importAnalysisPlugin,实现了 transform 钩子,当请求的是 js 脚本时,会通过 es-module-lexer 这个库分析出所有 import 语句。如果是裸导入,就分析出这个裸导入真正要导入的文件地址,然后转换为正确的导入 url。这个插件还会对 import.meta 进行增强,实现一些标准没有的功能,比如import.meta.hot
  • assetPlugin,实现了 load 钩子,让我们可以在代码中通过import imgUrl from './logo.png';的方式获得资源的 url。通过 import 导入的 png 图片,服务器不直接返回图片的数据,而是返回一个 js 模块,在模块中通过 export default ${imgUrl}的方式导出要请求的图片的 url。
  • resolvePlugin,实现了 resolveId 钩子,是一个比较重要的插件,用来转换 url 为真实路径。importAnalysisPlugin 插件中获取裸导入真正的文件地址的功能就是调用了这个插件实现的。
  • esbuildPlugin,实现了 transform 钩子,使用 esbuild 将ts、tsx 转换为 js。

转换index.html


image.png

在listen()之前执行vite钩子 buildStart,和runOptimize(),进行启动前的优化。然后返回server。


image.png

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容