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

文章目录

  • 前言
  • [(1)vue 项目构建的时候,通过package.json文件看到构建入口](#(1)vue 项目构建的时候,通过package.json文件看到构建入口)
  • [(2) 构建入口页面:导入同级模块config的getAllbuilds方法](#(2) 构建入口页面:导入同级模块config的getAllbuilds方法)
  • [(3) 通过传入参数中的builds对象使用map获取](#(3) 通过传入参数中的builds对象使用map获取)
  • [(4) 通过builds对象过滤后拿到了引入vue的文件](#(4) 通过builds对象过滤后拿到了引入vue的文件)
  • [(5) 通过第(4)步找到下一个导出vue的文件](#(5) 通过第(4)步找到下一个导出vue的文件)
  • [(6) 通过第(5)步找到下一个导出vue的文件](#(6) 通过第(5)步找到下一个导出vue的文件)
  • [(7) 通过第(6)步找到下一个导出vue的文件](#(7) 通过第(6)步找到下一个导出vue的文件)
  • [(8) 通过第(7)步找到下一个导出vue的文件](#(8) 通过第(7)步找到下一个导出vue的文件)
  • [(9) 最终发现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的原型拆分成多个文件,不同的逻辑按照代码的逻辑组织关系,有利于维护代码。

总结

相关推荐
Apifox19 分钟前
Apifox 11 月更新|AI 生成测试用例能力持续升级、JSON Body 自动补全、支持为响应组件添加描述和 Header
前端·后端·测试
木易士心20 分钟前
深入剖析:按下 F5 后,浏览器前端究竟发生了什么?
前端·javascript
在掘金8011022 分钟前
vue3中使用medium-zoom
前端·vue.js
xump43 分钟前
如何在DevTools选中调试一个实时交互才能显示的元素样式
前端·javascript·css
折翅嘀皇虫1 小时前
fastdds.type_propagation 详解
java·服务器·前端
Front_Yue1 小时前
深入探究跨域请求及其解决方案
前端·javascript
wordbaby1 小时前
React Native 进阶实战:基于 Server-Driven UI 的动态表单架构设计
前端·react native·react.js
抱琴_1 小时前
【Vue3】我用 Vue 封装了个 ECharts Hooks,同事看了直接拿去复用
前端·vue.js
风止何安啊1 小时前
JS 里的 “变量租房记”:闭包是咋把变量 “扣” 下来的?
前端·javascript·node.js
老华带你飞1 小时前
社区养老保障|智慧养老|基于springboot+小程序社区养老保障系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·小程序·毕设·社区养老保障