mirror of
https://gitee.com/vuejs/vue.git
synced 2024-11-29 18:47:39 +08:00
update project structure guide (close #5465)
This commit is contained in:
parent
914879f1ce
commit
a6d0e056cc
20
.github/CONTRIBUTING.md
vendored
20
.github/CONTRIBUTING.md
vendored
@ -73,10 +73,16 @@ The default test script will do the following: lint with ESLint -> type check wi
|
||||
|
||||
## Project Structure
|
||||
|
||||
- **`build`**: contains build-related configuration files. In most cases you don't need to touch them.
|
||||
- **`build`**: contains build-related configuration files. In most cases you don't need to touch them. However, it would be helpful to familiarize yourself with the following files:
|
||||
|
||||
- `build/alias.js`: module import aliases used across all source code and tests.
|
||||
|
||||
- `build/config.js`: contains the build configurations for all files found in `dist/`. Check this file if you want to find out the entry source file for a dist file.
|
||||
|
||||
- **`dist`**: contains built files for distribution. Note this directory is only updated when a release happens; they do not reflect the latest changes in development branches.
|
||||
|
||||
See [dist/README.md](https://github.com/vuejs/vue/blob/dev/dist/README.md) for more details on dist files.
|
||||
|
||||
- **`flow`**: contains type declarations for [Flow](https://flowtype.org/). These declarations are loaded **globally** and you will see them used in type annotations in normal source code.
|
||||
|
||||
- **`packages`**: contains `vue-server-renderer` and `vue-template-compiler`, which are distributed as separate NPM packages. They are automatically generated from the source code and always have the same version with the main `vue` package.
|
||||
@ -85,16 +91,6 @@ The default test script will do the following: lint with ESLint -> type check wi
|
||||
|
||||
- **`src`**: contains the source code, obviously. The codebase is written in ES2015 with [Flow](https://flowtype.org/) type annotations.
|
||||
|
||||
- **`entries`**: contains entries for different builds and packages.
|
||||
|
||||
- **`web-runtime`**: the entry for `dist/vue.common.js`, a.k.a the runtime-only build. It does not include the template to render function compiler, so it does not support the `template` option. **This is set as the `main` field in `package.json` so it is the default export when you import Vue as an NPM package.**
|
||||
|
||||
- **`web-runtime-with-compiler`**: the entry for `dist/vue.js`, a.k.a the standalone build. It includes the template to render function compiler. To use this build from the NPM packages, do `import Vue from 'vue/dist/vue'`, or alias `vue` to `vue/dist/vue` in your build tool configuration.
|
||||
|
||||
- **`web-compiler.js`**: the entry for the `vue-template-compiler` NPM package.
|
||||
|
||||
- **`web-server-renderer.js`**: the entry for the `vue-server-renderer` NPM package.
|
||||
|
||||
- **`compiler`**: contains code for the template-to-render-function compiler.
|
||||
|
||||
The compiler consists of a parser (converts template strings to element ASTs), an optimizer (detects static trees for vdom render optimization), and a code generator (generate render function code from element ASTs). Note the codegen directly generates code strings from the element AST - it's done this way for smaller code size because the compiler is shipped to the browser in the standalone build.
|
||||
@ -117,6 +113,8 @@ The default test script will do the following: lint with ESLint -> type check wi
|
||||
|
||||
- **`platforms`**: contains platform-specific code.
|
||||
|
||||
Entry files for dist builds are located in their respective platform directory.
|
||||
|
||||
Each platform module contains three parts: `compiler`, `runtime` and `server`, corresponding to the three directories above. Each part contains platform-specific modules/utilities which are then imported and injected to the core counterparts in platform-specific entry files. For example, the code implementing the logic behind `v-bind:class` is in `platforms/web/runtime/modules/class.js` - which is imported in `entries/web-runtime.js` and used to create the browser-specific vdom patching function.
|
||||
|
||||
- **`sfc`**: contains single-file component (`*.vue` files) parsing logic. This is used in the `vue-template-compiler` package.
|
||||
|
Loading…
Reference in New Issue
Block a user