警告
这篇文档是关于 @vue/cli,如果想看旧版本 vue-cli 的内容,点击这里
Vue Cli 是一套专门为 Vue.js 快速开发服务提供的全系统,提供了:
- 通过 @vue/cli 提供了交互工程脚手架
- 通过 @vue/cli 和 @vue/cli-service-global 提供了零配置快速原型
- 一个运行时依赖(@vue/cli-service)包括
- 可升级的
- 基于 webpack 进行构建,配置合理的默认值
- 通过工程中的配置文件进行配置
- 通过插件实现可扩展
- 一个集成了前端生态系统中最好工具的官方插件库
- 一个创建和管理 Vue.js 项目的全图形化用户界面
Vue Cli 目标是成为基于 vue 生态系统的标准工具。它确保大量的构建工具平稳运行并且有合理的初始值,因此让人专注于写应用而不是花大量的时间和配置文件打交道。与此同时,它提供了弹性方案去微调每个工具的配置而不需要额外的推进
系统组件
如果你去看源代码,就会发现 Vue Cli 有几个可移动的部分,它是包含一系列分离并已发布依赖包的收购站
CLI
CLI(@vue/cli) 是一个全局安装的 npm 依赖包,它在命令行提供 vue 命令,通过 vue create 提供了快速用脚手架搭建一个新项目的能力,或者通过 vue serve 实现快速原型的想法。也可以通过 vue ui 使用图形化用户界面来管理项目。接下来教程的一些片段,我们将浏览到它能实现什么。
CLI Service
CLI Service 是一个开发依赖,它是通过 @vue/cli 安装在每个本地项目的 npm 包。
CLI Service 基于 webpack 和 webapck-dev-server ,包括:
- 加载其他 CLI Plugins 的核心服务
- 优化大多数 app 的 webpack 内部配置
- 在工程里面的 vue-cli-service 加法器,包含基础的 serve,build 和 inspect 命令
如果你熟悉 create-react-app, 那么 @vue/cli-service 可以大致理解成 react-scripts,当然,实现细节还是不同的。
CLI Service 部分包含它的详细使用方法。
CLI Plugins
CLI Plugins 是可以在你的 Vue CLI 工程中提供可选功能的 npm 包, 比如 Babel/TypeScript 转换器,ESLint 集成,单元测试,端对端测试。可以很容易识别一个 Vue CLI plugin ,因为他们的名字是 @vue/cli-plugin-(内嵌 plugins) 或者 vue-cli-plugin- 开头(社区 plugins)
当你在项目中运行 vue-cli-service 加法器时,它会自动解析并加载在项目 package.json 中的所有 CLI Plugins。
plugins 能够在项目创建时添加或者在之后添加到项目中,他们可以被分组成可利用的预设。我们将在 Plugins and Presets部分进行深入的讨论。