vue-cli全局安装以后,提供了vue命令和vue init、vue list、vue build三个子命令,经过命令能够搭建基于vue.js的脚手架项目。本文简单介绍一下这些命令是如何实现的。javascript
以下图,由以前文章介绍,npm安装过程当中,能够利用package.json中bin字段的配置,将bin目录下的命令文件软连到全局命令。也就是说在/usr/local/bin下生成了四个软连命令:vue、vue-build、vue-list、vue-init。html
#!/usr/bin/env node require('commander') .version(require('../package').version) .usage('<command> [options]') .command('init', 'generate a new project from a template') .command('list', 'list available official templates') .command('build', 'prototype a new project') .parse(process.argv)
该命令采用commander.js来实现。commander的主要方法:vue
(1)parse:用于解析process.argv,将process.argv.slice(2)赋值给program.args;java
(2)command:建立子命令,子命令的使用方法是command <subcommand> [options],实际调用的命令是command-subcommand,如使用命令行执行vue list,实际上是在执行vue-list全局命令;node
(3)options:主要设置命令的参数,同时提供参数对应的说明文档,默认提供的option是--help。git
vue-init的主要功能是拉取指定git目录下的项目模板文件(官方或自制)到指定目录下,用法以下github
$ vue init <template-name> <project-name>
这里仍须要解析process.argv,因此在vue-init中又引入了commander.js,生成了一个programvue-cli
program .usage('<template-name> [project-name]') .option('--offline', 'use cached template') /** * Help. */ function help () { program.parse(process.argv) if (program.args.length < 1) return program.help() } help()
接下来就是要实现拉取模板文件,经处理后,放置到产出目录下,具体如何实现的,接下来会有专门的文章介绍vue-cli命令的实现原理,敬请期待!npm