HcySunYang 8 жил өмнө
parent
commit
596c494170
1 өөрчлөгдсөн 46 нэмэгдсэн , 0 устгасан
  1. 46 0
      了解Vue这个项目.md

+ 46 - 0
了解Vue这个项目.md

@@ -4,3 +4,49 @@
 
 详细目录介绍如下:
 
+```
+├── build --------------------------------- 构建相关的文件,一般情况下我们不需要动
+│   ├── 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 函数
+│   │   ├── parser ------------------------ 存放将模板字符串转换成元素抽象语法树的代码
+│   │   ├── codegen ----------------------- 存放从抽象语法树(AST)生成render函数的代码
+│   │   ├── optimizer.js ------------------ 分析静态树,优化vdom渲染
+│   ├── 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 的锁定文件
+├── circle.yml ---------------------------- circle 持续集成的配置文件
+├── .flowconfig --------------------------- flow 的配置文件
+├── .babelrc ------------------------------ babel 配置文件
+├── .eslintrc ----------------------------- eslint 配置文件
+├── .eslintignore ------------------------- eslint 忽略配置
+├── .gitignore ---------------------------- git 忽略配置
+```
+
+对于上面对目录和文件的描述也许你一眼看上去一头雾水,还是不理解他在干什么,没关系,这是正常的,在你没有深入到源码之前,仅仅凭借几句话就理解这个文件的作用是不可能的,所以不要灰心,只需要有个大概印象就可以了,混个眼熟。