当前位置: 首页 > article >正文

vue源码分析(二)——vue的入口发生了什么

文章目录

  • 前言
  • (1)vue 项目构建的时候,通过package.json文件看到构建入口
  • (2) 构建入口页面:导入同级模块config的getAllbuilds方法
  • (3) 通过传入参数中的builds对象使用map获取
  • (4) 通过builds对象过滤后拿到了引入vue的文件
  • (5) 通过第(4)步找到下一个导出vue的文件
  • (6) 通过第(5)步找到下一个导出vue的文件
  • (7) 通过第(6)步找到下一个导出vue的文件
  • (8) 通过第(7)步找到下一个导出vue的文件
  • (9) 最终发现Vue其实是个函数
  • 总结


前言

vue源码是基于rollup构建的,rollup是一个轻量级构建工具,非常适合js库的源码构建,因为它只编译js。


(1)vue 项目构建的时候,通过package.json文件看到构建入口

路径:vue\package.json

在这里插入图片描述

(2) 构建入口页面:导入同级模块config的getAllbuilds方法

路径:vue\scripts\build.js
在这里插入图片描述

(3) 通过传入参数中的builds对象使用map获取

builds中拿到所有的配置,然后通过命令行参数过滤掉不需要的配置,最后将入口配置返回到build.js中,并调用build方法进行构建。

路径:scripts\config.js

在这里插入图片描述

(4) 通过builds对象过滤后拿到了引入vue的文件

路径:vue\src\platforms\web\entry-runtime-with-compiler.ts

在这里插入图片描述

(5) 通过第(4)步找到下一个导出vue的文件

路径:vue\src\platforms\web\runtime-with-compiler.ts
注意点:这里挂载了$mounted方法

在这里插入图片描述

(6) 通过第(5)步找到下一个导出vue的文件

路径:vue\src\core\index.ts

在这里插入图片描述

(7) 通过第(6)步找到下一个导出vue的文件

路径:vue\src\core\index.ts

在这里插入图片描述

(8) 通过第(7)步找到下一个导出vue的文件

路径:vue\src\core\instance\index.ts

在这里插入图片描述

(9) 最终发现Vue其实是个函数

问题:为什么这里使用的es5的方法,而不是 es6 的 class ?
原因:如下图,第(8)步中的initMixin等方法(路径:vue\src\core\instance\init.ts)都是放到原型上的,将vue的原型拆分成多个文件,不同的逻辑按照代码的逻辑组织关系,有利于维护代码。

在这里插入图片描述

在这里插入图片描述

总结


http://www.kler.cn/a/105068.html

相关文章:

  • 【C++笔记】C++继承
  • 【python海洋专题S2】找范围的语句进阶版本V2
  • Python循环语句(二)
  • Proteus仿真--量程自动切换数字电压表(仿真+程序)
  • UE4/5 竖排文字文本
  • asp.net core webapi signalR通信
  • Spring Boot + EasyUI 创建第一个项目(一)
  • 聊聊“JVM 调优JVM 性能优化”是怎么个事?
  • Server Name Indication(SNI),HTTP/TLS握手过程解析
  • Hafnium安全分区管理器和示例参考软件栈
  • DB-GPT发布:用私有LLM技术彻底改革数据库互动
  • 【软件测试】了解JUnit单元测试框架常用注解
  • 导致爬虫无法使用的原因有哪些?
  • spring cloud Eureka集群模式搭建(IDEA中运行)《二》
  • 0036【Edabit ★☆☆☆☆☆】【让我加油】Let‘s Fuel Up!
  • 项目管理之如何有效定义项目目标
  • Android12 启动页适配
  • PX4天大bug,上电反复重启,连不上QGC!
  • 【openGauss】一主一备实现主备节点切换实验(switchover、failover)
  • 2023全新TwoNav开源网址导航系统源码 | 去授权版