美文网首页
vue源码目录结构

vue源码目录结构

作者: RiverSouthMan | 来源:发表于2019-03-20 15:25 被阅读0次

    源码目录

    ├── scripts ------------------------------- 构建相关的文件,一般情况下我们不需要动
    │   ├── git-hooks ------------------------- 存放git钩子的目录
    │   ├── alias.js -------------------------- 别名配置
    │   ├── config.js ------------------------- 生成rollup配置的文件
    │   ├── build.js -------------------------- 对 config.js 中所有的rollup配置进行构建
    │   ├── ci.sh ----------------------------- 持续集成运行的脚本
    │   ├── release.sh ------------------------ 用于自动发布新版本的脚本
    ├── dist ---------------------------------- 构建后文件的输出目录
    ├── examples ------------------------------ 存放一些使用Vue开发的应用案例
    ├── flow ---------------------------------- 类型声明,使用开源项目 [Flow](https://flowtype.org/)
    ├── packages ------------------------------ 存放独立发布的包的目录
    ├── test ---------------------------------- 包含所有测试文件
    ├── src ----------------------------------- 这个是我们最应该关注的目录,包含了源码
    │   ├── compiler -------------------------- 编译器代码的存放目录,将 template 编译为 render 函数
    │   ├── core ------------------------------ 存放通用的,与平台无关的代码
    │   │   ├── observer ---------------------- 响应系统,包含数据观测的核心代码
    │   │   ├── vdom -------------------------- 包含虚拟DOM创建(creation)和打补丁(patching)的代码
    │   │   ├── instance ---------------------- 包含Vue构造函数设计相关的代码
    │   │   ├── global-api -------------------- 包含给Vue构造函数挂载全局方法(静态方法)或属性的代码
    │   │   ├── components -------------------- 包含抽象出来的通用组件
    │   ├── server ---------------------------- 包含服务端渲染(server-side rendering)的相关代码
    │   ├── platforms ------------------------- 包含平台特有的相关代码,不同平台的不同构建的入口文件也在这里
    │   │   ├── web --------------------------- web平台
    │   │   │   ├── entry-runtime.js ---------- 运行时构建的入口,不包含模板(template)到render函数的编译器,所以不支持 `template` 选项,我们使用vue默认导出的就是这个运行时的版本。大家使用的时候要注意
    │   │   │   ├── entry-runtime-with-compiler.js -- 独立构建版本的入口,它在 entry-runtime 的基础上添加了模板(template)到render函数的编译器
    │   │   │   ├── entry-compiler.js --------- vue-template-compiler 包的入口文件
    │   │   │   ├── entry-server-renderer.js -- vue-server-renderer 包的入口文件
    │   │   │   ├── entry-server-basic-renderer.js -- 输出 packages/vue-server-renderer/basic.js 文件
    │   │   ├── weex -------------------------- 混合应用
    │   ├── sfc ------------------------------- 包含单文件组件(.vue文件)的解析逻辑,用于vue-template-compiler包
    │   ├── shared ---------------------------- 包含整个代码库通用的代码
    ├── package.json -------------------------- 不解释
    ├── yarn.lock ----------------------------- yarn 锁定文件
    ├── .editorconfig ------------------------- 针对编辑器的编码风格配置文件
    ├── .flowconfig --------------------------- flow 的配置文件
    ├── .babelrc ------------------------------ babel 配置文件
    ├── .eslintrc ----------------------------- eslint 配置文件
    ├── .eslintignore ------------------------- eslint 忽略配置
    ├── .gitignore ---------------------------- git 忽略配置
    

    对不同构建版本的解释

    NPM 包的 dist/ 目录你将会找到很多不同的 Vue.js 构建版本。这里列出了它们之间的差别:

    UMD CommonJS ES Module (基于构建工具使用) ES Module (直接用于浏览器)
    完整版 vue.js vue.common.js vue.esm.js vue.esm.browser.js
    只包含运行时版 vue.runtime.js vue.runtime.common.js vue.runtime.esm.js -
    完整版 (生产环境) vue.min.js - - vue.esm.browser.min.js
    只包含运行时版 (生产环境) vue.runtime.min.js - - -

    术语

    • 完整版:同时包含编译器和运行时的版本。

    • 编译器:用来将模板字符串编译成为 JavaScript 渲染函数的代码。

    • 运行时:用来创建 Vue 实例、渲染并处理虚拟 DOM 等的代码。基本上就是除去编译器的其它一切。

    • UMD:UMD 版本可以通过 <script> 标签直接用在浏览器中。jsDelivr CDN 的 https://cdn.jsdelivr.net/npm/vue 默认文件就是运行时 + 编译器的 UMD 版本 (vue.js)。

    • CommonJS:CommonJS 版本用来配合老的打包工具比如 Browserifywebpack 1。这些打包工具的默认文件 (pkg.main) 是只包含运行时的 CommonJS 版本 (vue.runtime.common.js)。

    • ES Module:从 2.6 开始 Vue 会提供两个 ES Modules (ESM) 构建文件:

      • 为打包工具提供的 ESM:为诸如 webpack 2Rollup 提供的现代打包工具。ESM 格式被设计为可以被静态分析,所以打包工具可以利用这一点来进行“tree-shaking”并将用不到的代码排除出最终的包。为这些打包工具提供的默认文件 (pkg.module) 是只有运行时的 ES Module 构建 (vue.runtime.esm.js)。

      • 为浏览器提供的 ESM (2.6+):用于在现代浏览器中通过 <script type="module"> 直接导入。

    package.json

    image.png
    • main对应的cjs模块
    • module对应的是es模块
    {
      "scripts": {
        "dev": "rollup -w -c scripts/config.js --environment TARGET:web-full-dev",
        "dev:cjs": "rollup -w -c scripts/config.js --environment TARGET:web-runtime-cjs",
        "dev:esm": "rollup -w -c scripts/config.js --environment TARGET:web-runtime-esm",
        "dev:test": "karma start test/unit/karma.dev.config.js",
        "dev:ssr": "rollup -w -c scripts/config.js --environment TARGET:web-server-renderer",
        "dev:compiler": "rollup -w -c scripts/config.js --environment TARGET:web-compiler ",
        "dev:weex": "rollup -w -c scripts/config.js --environment TARGET:weex-framework",
        "dev:weex:factory": "rollup -w -c scripts/config.js --environment TARGET:weex-factory",
        "dev:weex:compiler": "rollup -w -c scripts/config.js --environment TARGET:weex-compiler ",
        "build": "node scripts/build.js",
        "build:ssr": "npm run build -- web-runtime-cjs,web-server-renderer",
        "build:weex": "npm run build -- weex",
        "commit": "git-cz"
      },
    }
    

    package.jsonscript字段,有不同版本的构建命令。以"build": "node scripts/build.js"为入口,找到构建脚本build.js

    找到vue构造函数在/src/core/instance/index.js这个文件中

    import { initMixin } from './init'
    import { stateMixin } from './state'
    import { renderMixin } from './render'
    import { eventsMixin } from './events'
    import { lifecycleMixin } from './lifecycle'
    import { warn } from '../util/index'
    
    function Vue (options) {
      if (process.env.NODE_ENV !== 'production' &&
        !(this instanceof Vue)
      ) {
        warn('Vue is a constructor and should be called with the `new` keyword')
      }
      this._init(options)
    }
    
    initMixin(Vue)
    stateMixin(Vue)
    eventsMixin(Vue)
    lifecycleMixin(Vue)
    renderMixin(Vue)
    
    export default Vue
    

    实例一个vue对象是通过new操作符new Vue()完成的,构造函数如果不是通过new操作符调用的话会给出警告⚠️。最后调用了内置函数_init(options),这个函数在initMixin中定义

    • initMixin(Vue)
    export function initMixin (Vue: Class<Component>) {
      Vue.prototype._init = function (options?: Object) {
        ...
      }
    }
    

    相关文章

      网友评论

          本文标题:vue源码目录结构

          本文链接:https://www.haomeiwen.com/subject/jjebmqtx.html