Vue.js 框架源码与进阶 - Vue.js 3.0 介绍

15.1 源码组织方式

  • 采用 TypeScript 的方式重写

    • 为了提升代码的可维护性,Vue 3.x 的源码全部采用 TypeScript 编写
    • 大型项目的开发都推荐使用类型化的语言,在编码的过程当中帮我们检查类型的问题
  • 使用 Monorepo 管理项目结构

    • 把独立的功能模块都提取到不同的包中,每个功能模块之间的划分明确,模块之间的依赖关系也明确
    • 每个功能模块都可以单独测试、单独发布以及单独使用

packages 目录结构

image.png
  • packages 目录下都是独立发行的包,可以独立使用
    • compiler - xxx 跟编译相关的代码
      • compiler-core 与平台无关的编译器
      • compiler-dom 浏览器平台下的编译器,依赖于 compiler-core
      • compiler-sfc 用来编译单文件组件,依赖于 compiler-core 与 compiler-dom
      • compiler-ssr 服务端渲染的编译器,依赖于 compiler-dom
    • reactivity 数据响应式系统,可以独立使用
    • runtime - xxx 跟运行时相关的代码
      • runtime-core 与平台无关的运行时
      • runtime-dom 针对浏览器的运行时,处理 原生DOM 的 API、事件等
      • runtime-test 专门为测试编写的轻量级的运行时,这个运行时渲染出来的DOM树其实是一个JS对象,可以运行在所有的运行环境
    • server-renderer 用于服务端渲染
    • shared Vue内部使用的一些公共 API
    • size-check 私有的包,不会发不到 Npm,作用是在 Tree-shaking 之后检查包的大小
    • template-explorer 在浏览器运行的实时编译组件,会输出render函数,README.md 提供在线访问地址
    • vue 用来构建完整版的 Vue,依赖于 compiler 和 runtime

15.2 不同的构建版本

Vue 3.x 在构建时与 Vue 2.x 类似都构建了不同的版本

和 Vue 2.x 不同的是,Vue 3.x 中不再构建 UMD 模块化的方式,因为其会让代码有更多的冗余,它要支持多种模块化的方式

Vue 3.x 的构建版本中把 cjs、ESModule 和 自执行函数 的方式分别打包到了不同的文件中

  • packages/vue 存放了 Vue 3.x 中的所有构建版本
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值